@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Noto+Sans+SC:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";:root{color-scheme:light;--sidebar-w: 240px;--sidebar-collapsed: 68px;--bg: #f7f6f3;--surface: #ffffff;--surface2: #f2f0ec;--surface3: #fffaf7;--border: #e8e5df;--border2: #d4d0c8;--text: #1a1917;--text2: #6b6860;--text3: #9e9b93;--accent: #e8735a;--accent2: #5b8dd9;--teal: #4ab5a0;--pink: #e87b9e;--nav-active-bg: #fdf0ec;--focus-bg: #ffffff;--focus-ring: rgba(232,115,90,.08);--danger-bg: #fce4ec;--danger-text: #c62828;--danger-bg-hover: #f8bbd0;--danger-dot: #ef5350;--success-bg: #e8f5e9;--success-text: #2e7d32;--success-dot: #43a047;--warning-bg: #fff8e1;--warning-text: #e65100;--warning-dot: #ffa726;--info-bg: #e6f1fb;--info-text: #185fa5;--muted-pill-bg: #f2f0ec;--muted-pill-text: #6b6860;--role-developer-bg: #e8e5df;--role-developer-text: #1a1917;--avatar-bg: linear-gradient(135deg, #fde8e2, #fbc5b8);--avatar-info-bg: #e6f1fb;--avatar-info-text: #185fa5;--avatar-success-bg: #e1f5ee;--avatar-success-text: #0f6e56;--modal-overlay: rgba(26,25,23,.4);--r-sm: 10px;--r-md: 14px;--r-lg: 18px;--r-xl: 22px;--shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.07), 0 8px 32px rgba(0,0,0,.05);--font: "Inter", "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--mono: "DM Mono", monospace;--transition: .22s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{color-scheme:dark;--bg: #11100f;--surface: #1a1816;--surface2: #25221f;--surface3: #2d2420;--border: #34302b;--border2: #4a433c;--text: #f2eee8;--text2: #bbb2a8;--text3: #81786f;--accent: #ff8d6f;--accent2: #8bb8ff;--teal: #62d4bd;--pink: #f08aac;--nav-active-bg: rgba(255,141,111,.14);--focus-bg: #201d1a;--focus-ring: rgba(255,141,111,.16);--danger-bg: rgba(244,99,130,.16);--danger-text: #ff9aad;--danger-bg-hover: rgba(244,99,130,.24);--danger-dot: #ff708f;--success-bg: rgba(98,212,189,.14);--success-text: #78e6cf;--success-dot: #62d4bd;--warning-bg: rgba(255,183,77,.14);--warning-text: #ffc36b;--warning-dot: #ffb74d;--info-bg: rgba(139,184,255,.14);--info-text: #9fc4ff;--muted-pill-bg: #25221f;--muted-pill-text: #bbb2a8;--role-developer-bg: #34302b;--role-developer-text: #f2eee8;--avatar-bg: linear-gradient(135deg, rgba(255,141,111,.26), rgba(240,138,172,.2));--avatar-info-bg: rgba(139,184,255,.16);--avatar-info-text: #9fc4ff;--avatar-success-bg: rgba(98,212,189,.16);--avatar-success-text: #78e6cf;--modal-overlay: rgba(0,0,0,.58);--shadow: 0 1px 3px rgba(0,0,0,.24), 0 8px 24px rgba(0,0,0,.18);--shadow-md: 0 2px 8px rgba(0,0,0,.28), 0 14px 40px rgba(0,0,0,.24)}[data-theme=dark] .btn-primary,[data-theme=dark] .btn.primary{background:linear-gradient(135deg,var(--accent),#d4664e);color:#fff;border:none}[data-theme=dark] .btn-primary:hover,[data-theme=dark] .btn.primary:hover{opacity:1;box-shadow:0 4px 18px #ff8d6f4d}[data-theme=dark] .btn-outline{background:var(--surface2);border-color:var(--border2);color:var(--text2)}[data-theme=dark] .btn-outline:hover:not(:disabled){background:var(--surface3);border-color:var(--text3);color:var(--text);box-shadow:0 2px 8px #0003}[data-theme=dark] .btn-danger{background:var(--danger-bg);color:var(--danger-text);border:1px solid rgba(244,99,130,.2)}[data-theme=dark] .btn-danger:hover{border-color:#f4638259;box-shadow:0 2px 10px #f4638226}[data-theme=dark] .action-btn{background:var(--surface2);border-color:var(--border2);color:var(--text2)}[data-theme=dark] .action-btn:hover{background:var(--surface3);color:var(--text);border-color:var(--text3);box-shadow:0 2px 8px #0000003d}[data-theme=dark] .action-btn-danger{color:var(--danger-text)}[data-theme=dark] .action-btn-danger:hover{background:var(--danger-bg);border-color:var(--danger-text);color:var(--danger-text)}[data-theme=dark] .action-btn-accent{color:var(--accent)}[data-theme=dark] .action-btn-accent:hover{background:var(--nav-active-bg);border-color:var(--accent);color:var(--accent)}[data-theme=dark] .toggle-slider{background:var(--border2)}[data-theme=dark] .toggle-slider:before{background:var(--text2);box-shadow:0 1px 3px #0000004d}[data-theme=dark] .toggle-switch input:checked+.toggle-slider:before{background:#fff}[data-theme=dark] .token-btn{color:var(--text3)}[data-theme=dark] .token-btn:hover{color:var(--accent)}[data-theme=dark] .online-player-avatar{background:linear-gradient(135deg,#8bb8ff38,#8bb8ff1f);color:var(--accent2)}[data-theme=dark] .online-player-tag{background:var(--surface3);color:var(--text3)}[data-theme=dark] .online-player-tag-tag-ping{color:var(--teal);background:var(--success-bg)}[data-theme=dark] .online-player-ban-form,[data-theme=dark] .online-player-action-form{background:var(--surface2);border-top-color:var(--border)}[data-theme=dark] .action-form-input{background:var(--surface);border-color:var(--border);color:var(--text)}[data-theme=dark] .ban-form-field select{background:var(--surface);border-color:var(--border2);color:var(--text)}[data-theme=dark] .online-player-count{background:var(--surface3);color:var(--text3)}[data-theme=dark] .online-player-card:hover{border-color:var(--border2);box-shadow:0 2px 10px #0003}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}html,body,#root{min-height:100%}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit;color:var(--text)}input,textarea,select{background:var(--surface);color:var(--text)}input::placeholder,textarea::placeholder{color:var(--text3)}input:disabled,textarea:disabled,select:disabled{background:var(--surface2);color:var(--text3);cursor:not-allowed;opacity:.7}select option{background-color:#fff;color:#1a1917}[data-theme=dark] select option{background-color:#1a1816;color:#f2eee8}input[type=checkbox],input[type=radio]{accent-color:var(--accent)}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,var(--surface) 0%,color-mix(in srgb,var(--surface) 97%,var(--accent)) 100%);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;transition:width .28s cubic-bezier(.4,0,.2,1);z-index:1000;overflow:hidden}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed)}.sidebar-logo,.brand{display:flex;align-items:center;gap:10px;padding:20px 16px 18px;border-bottom:1px solid var(--border);white-space:nowrap;position:relative}.logo-mark,.brand-mark{width:34px;height:34px;background:linear-gradient(135deg,var(--accent),#f0a07a);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;box-shadow:0 3px 10px #e8735a40}.logo-mark svg,.brand-mark svg{width:17px;height:17px}.logo-text,.brand-text{font-size:15px;font-weight:700;letter-spacing:-.4px;background:linear-gradient(135deg,var(--text) 30%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:opacity .2s}.logo-text span,.brand-text span{-webkit-text-fill-color:var(--accent);background:none}.sidebar-collapse-btn,.collapse-btn{position:absolute;top:22px;right:-12px;width:24px;height:24px;background:var(--surface);border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10;box-shadow:0 1px 4px #0000000f}.sidebar-collapse-btn:hover,.collapse-btn:hover{background:var(--accent);border-color:var(--accent);box-shadow:0 2px 8px #e8735a40}.sidebar-collapse-btn:hover svg,.collapse-btn:hover svg{color:#fff}.sidebar-collapse-btn svg,.collapse-btn svg{width:10px;height:10px;color:var(--text2);transition:transform .28s cubic-bezier(.4,0,.2,1),color .2s}.sidebar-collapsed .sidebar-collapse-btn svg{transform:rotate(180deg)}.nav-section,.nav-group{padding:12px 8px 0;flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .3s}.nav-section:hover{scrollbar-color:var(--border2) transparent}.nav-label{font-size:10.5px;font-weight:600;letter-spacing:.6px;color:var(--text3);text-transform:uppercase;padding:10px 12px 8px;white-space:nowrap;overflow:hidden;transition:opacity .2s,letter-spacing .2s;display:flex;align-items:center;gap:8px}.nav-label:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent);opacity:.6}.sidebar-collapsed .nav-label{opacity:0;letter-spacing:0}.sidebar-collapsed .nav-label:after{display:none}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;cursor:pointer;color:var(--text2);font-size:13.5px;font-weight:500;white-space:nowrap;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;margin-bottom:1px;background:transparent;border:none;width:100%;text-align:left;overflow:hidden}.nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:16px;border-radius:0 3px 3px 0;background:var(--accent);transition:transform .2s cubic-bezier(.4,0,.2,1)}.nav-item:hover{background:var(--surface2);color:var(--text);padding-left:16px}.nav-item:hover:before{transform:translateY(-50%) scaleY(1)}.nav-item.active{background:linear-gradient(135deg,var(--nav-active-bg) 0%,color-mix(in srgb,var(--nav-active-bg) 60%,transparent) 100%);color:var(--accent);font-weight:600;box-shadow:none;padding-left:16px}.nav-item.active:before{transform:translateY(-50%) scaleY(1);height:20px}.nav-item svg{width:17px;height:17px;flex-shrink:0;stroke-width:1.6;transition:all .2s}.nav-item:hover svg{color:var(--text)}.nav-item.active svg{color:var(--accent);filter:drop-shadow(0 1px 2px rgba(232,115,90,.25))}.nav-group-block{margin-bottom:8px}.nav-group-block:last-child{margin-bottom:0}.nav-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-collapsed .nav-item{padding:9px;justify-content:center}.sidebar-collapsed .nav-item:hover{padding-left:9px}.sidebar-collapsed .nav-item:hover:before{display:none}.sidebar-collapsed .nav-item.active{padding-left:9px}.sidebar-collapsed .nav-item.active:before{display:none}.sidebar-collapsed .nav-text,.sidebar-collapsed .nav-item span{opacity:0;width:0;display:none}.nav-collapsible-group{margin-bottom:1px}.nav-parent-item{position:relative}.nav-parent-item.child-active{color:var(--text);font-weight:600}.nav-chevron{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;flex-shrink:0;transition:transform .22s cubic-bezier(.4,0,.2,1);color:var(--text3)}.nav-chevron svg{width:10px;height:10px}.nav-chevron.expanded{transform:rotate(180deg)}.nav-parent-item:hover .nav-chevron{color:var(--text2)}.nav-sub-menu{overflow:hidden;animation:subMenuIn .22s cubic-bezier(.4,0,.2,1);padding:2px 0}@keyframes subMenuIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}.nav-sub-item{padding-left:46px!important;font-size:13px!important;font-weight:400!important;border-radius:8px!important;margin-bottom:0!important}.nav-sub-item:hover{padding-left:50px!important}.nav-sub-item.active{padding-left:50px!important;background:var(--nav-active-bg);color:var(--accent);font-weight:500!important}.nav-sub-item:before{left:30px!important}.nav-sub-item.active:before{transform:translateY(-50%) scaleY(1)!important;height:14px!important;left:30px!important}.sidebar-collapsed .nav-chevron,.sidebar-collapsed .nav-sub-menu{display:none}.sidebar-footer{padding:10px 8px;border-top:1px solid var(--border);background:linear-gradient(180deg,transparent 0%,color-mix(in srgb,var(--surface) 95%,var(--accent)) 100%)}.user-card,.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;transition:background .2s}.user-card:hover{background:var(--surface2)}.user-info{flex:1;min-width:0}.user-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.2}.user-role{font-size:11px;color:var(--text3);margin-top:1px}.avatar{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;background:linear-gradient(135deg,var(--accent),#f0a07a);color:#fff;box-shadow:0 2px 8px #e8735a33}.avatar-accent{background:linear-gradient(135deg,var(--accent2),#7eb8ff);box-shadow:0 2px 8px #5b8dd933}.logout-btn{padding:6px 14px;font-size:12px;font-weight:500;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;flex-shrink:0;transition:all .2s;display:inline-flex;align-items:center;gap:5px}.logout-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px #e8735a40;transform:translateY(-1px)}.logout-icon{flex-shrink:0}.logout-text{white-space:nowrap}.sidebar-collapsed .user-card{justify-content:center;padding:10px 8px}.sidebar-collapsed .user-info{display:none!important}.sidebar-collapsed .logout-btn{padding:6px;min-width:0}.sidebar-collapsed .logout-text{display:none}.main,.app-main{margin-left:var(--sidebar-w);flex:1;transition:margin-left var(--transition);min-height:100vh;display:flex;flex-direction:column;min-width:0}.sidebar-collapsed .main,.sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed)}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;height:62px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:color-mix(in srgb,var(--surface) 88%,transparent)}.search-box,.searchbar{flex:1;max-width:380px;display:flex;align-items:center;gap:9px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:7px 14px;transition:all .2s ease;min-width:0}.search-box:focus-within,.searchbar:focus-within{border-color:var(--accent);background:var(--focus-bg);box-shadow:0 0 0 3px var(--focus-ring),0 2px 8px #e8735a14}.search-box svg,.searchbar svg{flex-shrink:0;width:15px;height:15px;color:var(--text3)}.search-box input,.searchbar input{border:none;background:transparent;font-family:var(--font);font-size:13.5px;color:var(--text);outline:none;width:100%;min-width:0;text-overflow:ellipsis}.search-shortcut,.searchbar span{font-size:11px;color:var(--text3);background:var(--surface2);padding:2px 8px;border-radius:6px;border:1px solid var(--border);white-space:nowrap;flex-shrink:0}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:10px;flex-shrink:0}.topbar-divider{width:1px;height:22px;background:var(--border);margin:0 4px}.theme-toggle{height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text2);cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition);white-space:nowrap}.theme-toggle:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.theme-toggle.compact{width:36px;padding:0}.theme-toggle-icon{font-size:15px;line-height:1}.icon-btn{width:36px;height:36px;min-width:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);cursor:pointer;position:relative;transition:background var(--transition);color:var(--text2);background:transparent;border:none}.icon-btn:hover{background:var(--surface2)}.icon-btn svg{width:18px;height:18px;min-width:18px;flex-shrink:0;stroke-width:1.5}.notif-dot{position:absolute;top:7px;right:7px;width:7px;height:7px;background:var(--accent);border-radius:50%;border:1.5px solid var(--surface)}.topbar-avatar{width:34px;height:34px;min-width:34px;border-radius:50%;border:2px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fde8e2,#fbc5b8);font-size:13px;font-weight:600;color:var(--accent);flex-shrink:0}.content-section,.page{padding:24px 28px 40px;display:block;animation:fadeIn .35s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text3);margin-bottom:16px;padding:0}.breadcrumb .sep{color:var(--border2);margin:0 2px}.breadcrumb .current{color:var(--accent);font-weight:600}.page-header{margin-bottom:24px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:14px;position:relative;padding-bottom:18px}.page-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--accent) 0%,var(--accent2) 40%,var(--teal) 70%,transparent 100%);opacity:.25}.page-title,.page h1{font-size:22px;font-weight:700;letter-spacing:-.5px;margin:0;background:linear-gradient(135deg,var(--text) 0%,color-mix(in srgb,var(--text) 70%,var(--accent)) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-sub,.page p,.card p{font-size:13.5px;color:var(--text2);margin-top:4px;line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 20px;border-radius:11px;font-size:13.5px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .2s ease;white-space:nowrap;position:relative;overflow:hidden;letter-spacing:.1px;line-height:1.4}.btn-primary,.btn.primary{background:linear-gradient(135deg,var(--text),color-mix(in srgb,var(--text) 85%,#000));color:var(--surface)}.btn-primary:hover,.btn.primary:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 4px 16px #00000026}.btn-outline{background:var(--surface);border-color:var(--border2);color:var(--text2)}.btn-outline:hover:not(:disabled){background:var(--bg);border-color:var(--text);color:var(--text);transform:translateY(-1px);box-shadow:0 2px 8px #0000000f}.btn-outline:disabled{opacity:.45;cursor:not-allowed}.btn-accent,.btn.accent{background:linear-gradient(135deg,var(--accent),#f08a6a);color:#fff;box-shadow:0 2px 10px #e8735a4d}.btn-accent:hover,.btn.accent:hover{box-shadow:0 4px 18px #e8735a73;transform:translateY(-2px)}.btn-danger,.btn.danger{background:var(--danger-bg);color:var(--danger-text);border-color:#dc262626}.btn-danger:hover{background:var(--danger-bg-hover);transform:translateY(-1px);box-shadow:0 2px 8px #dc26261a}.btn-success{background:var(--success-bg);color:var(--success-text);border-color:#4ab5a033}.btn-success:hover{background:color-mix(in srgb,var(--success-bg) 80%,#000);transform:translateY(-1px);box-shadow:0 2px 8px #4ab5a01a}.btn.full{width:100%;margin-top:8px}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 1px 2px #0000000a;overflow:hidden;margin-bottom:20px;transition:box-shadow .25s ease,border-color .25s ease;position:relative}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--teal));opacity:0;transition:opacity .3s;border-radius:16px 16px 0 0}.card:hover{box-shadow:0 2px 12px #0000000f;border-color:var(--border2)}.card:hover:before{opacity:.6}.card-header{padding:20px 24px 16px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px}.card-title{font-size:15px;font-weight:600;color:var(--text);letter-spacing:-.2px}.card-sub{font-size:12.5px;color:var(--text3);margin-top:3px}.card-body{padding:16px 24px 22px}.table-responsive,.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.data-table,table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;min-width:650px}.data-table th,th{text-align:left;padding:11px 16px;font-size:11px;font-weight:600;color:var(--text3);border-bottom:2px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.6px;background:var(--surface2);position:sticky;top:0;z-index:1}.data-table th:first-child{border-radius:0}.data-table td,td{padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}.data-table tbody tr{transition:background .15s ease}.data-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg) 50%,transparent)}.data-table tbody tr:hover{background:color-mix(in srgb,var(--accent) 5%,var(--surface))}.data-table tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--accent)}.data-table tbody tr:last-child td{border-bottom:none}.user-cell{display:flex;align-items:center;gap:10px;font-weight:500}.steam-id{font-family:var(--mono);font-size:12.5px;color:var(--accent2)}.status-pill,.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:11.5px;font-weight:500;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease;letter-spacing:.1px}.status-pill:before,.pill:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.45}}.pill-online{background:var(--success-bg);color:var(--success-text)}.pill-online:before{background:var(--success-dot);box-shadow:0 0 5px var(--success-dot)}.pill-offline,.pill.muted{background:var(--surface2);color:var(--text2)}.pill-offline:before,.pill.muted:before{background:var(--text3);animation:none}.pill-danger{background:var(--danger-bg);color:var(--danger-text)}.pill-danger:before{background:var(--danger-dot);box-shadow:0 0 5px var(--danger-dot)}.pill-warning{background:var(--warning-bg);color:var(--warning-text)}.pill-warning:before{background:var(--warning-dot);box-shadow:0 0 5px var(--warning-dot)}.pill-info{background:var(--info-bg);color:var(--info-text)}.pill-info:before{background:var(--info-text);box-shadow:0 0 5px var(--info-text)}.pill-accent{background:var(--nav-active-bg);color:var(--accent)}.pill-accent:before{background:var(--accent);box-shadow:0 0 5px var(--accent)}.pill-default{background:var(--surface2);color:var(--text2)}.pill-default:before{background:var(--text3);animation:none}.pill-success{background:var(--success-bg);color:var(--success-text)}.pill-success:before{background:var(--success-dot);box-shadow:0 0 5px var(--success-dot)}.filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg) 50%,transparent)}.filter-bar .searchbar,.filter-bar .search-box,.filter-bar .search-bar{flex:1;min-width:200px;margin-bottom:0;display:flex;align-items:center}.filter-bar .search-bar-input{max-width:none;height:38px;padding:0 14px;font-size:13px}.filter-select{width:auto;min-width:120px;height:38px;padding:0 32px 0 12px;border:1px solid var(--border);border-radius:10px;font-size:13px;background:var(--surface);color:var(--text);outline:none;cursor:pointer;transition:all .2s;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239e9b93' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.filter-select:hover{border-color:var(--border2)}.filter-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring)}.filter-select option{background-color:#fff;color:#1a1917}[data-theme=dark] .filter-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2381786f' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E")}[data-theme=dark] .filter-select option{background-color:#1a1816;color:#f2eee8}.method-badge{font-family:var(--mono);font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;letter-spacing:.5px}.method-get{background:var(--success-bg);color:var(--success-text)}.method-post{background:var(--info-bg);color:var(--info-text)}.method-put{background:var(--warning-bg);color:var(--warning-text)}.method-delete,.metric-badge.danger,.badge-danger{background:var(--danger-bg);color:var(--danger-text)}.whitelist-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.whitelist-stat-item{text-align:center;padding:12px 0;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg)}.whitelist-stat-value{font-size:22px;font-weight:600}.whitelist-stat-label{font-size:11px;color:var(--text3);margin-top:4px;text-transform:uppercase}.badge-info{background:var(--info-bg);color:var(--info-text)}.role-badge{font-size:11.5px;padding:3px 10px;border-radius:20px;font-weight:600;letter-spacing:.3px;display:inline-flex;align-items:center;gap:4px}.role-badge.developer{background:linear-gradient(135deg,var(--role-developer-bg),#d8d4cc);color:var(--role-developer-text);box-shadow:0 1px 2px #0000000f}.role-badge.admin{background:linear-gradient(135deg,var(--info-bg),#d0e4f7);color:var(--info-text);box-shadow:0 1px 2px #0000000f}.role-badge.normal{background:var(--muted-pill-bg);color:var(--muted-pill-text);box-shadow:0 1px 2px #0000000a}.avatar-info{background:linear-gradient(135deg,var(--avatar-info-bg),#d6e9f9);color:var(--avatar-info-text)}.avatar-success{background:linear-gradient(135deg,var(--avatar-success-bg),#d1f0e6);color:var(--avatar-success-text)}.tabs{display:flex;gap:4px;background:var(--surface2);padding:4px;border-radius:12px;width:fit-content;margin-bottom:20px;flex-wrap:wrap}.tab{padding:7px 22px;font-size:13px;font-weight:500;border-radius:10px;cursor:pointer;color:var(--text2);transition:all .2s ease;white-space:nowrap;border:none;background:transparent;position:relative}.tab:hover{color:var(--text)}.tab.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 3px #00000014,0 2px 8px #e8735a14;font-weight:600}.metrics-grid,.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px 20px 16px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform var(--transition),box-shadow var(--transition)}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--teal));opacity:.8}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-label{font-size:12px;font-weight:500;color:var(--text2);text-transform:uppercase;margin-bottom:10px;display:flex;justify-content:space-between}.metric-badge{font-size:11px;padding:2px 8px;border-radius:20px;text-transform:none;background:var(--success-bg);color:var(--success-text)}.metric-value{font-size:26px;font-weight:600;margin-bottom:12px;background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.metric-chart-wrap,.metric-chart-wrap canvas,.sparkline,.chart-placeholder{height:48px;width:100%;position:relative;border-radius:12px}.lower-grid{display:grid;grid-template-columns:1fr 340px;gap:16px}.dash-hero{background:linear-gradient(135deg,var(--surface),var(--surface2));border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 30px;margin-bottom:22px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);position:relative;overflow:hidden}.dash-hero:before{content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(232,115,90,.08) 0%,transparent 70%);border-radius:50%}.dash-hero-title{font-size:22px;font-weight:700;letter-spacing:-.5px;margin-bottom:4px}.dash-hero-sub{font-size:13.5px;color:var(--text2)}.dash-hero-badge{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-lg);background:var(--bg);border:1px solid var(--border);font-size:12px;color:var(--text3);flex-shrink:0}.dash-section-label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}.dash-section-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.dash-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.dash-overview-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 18px 16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}.dash-overview-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.dash-overview-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-icon-server{background:#5b8dd91f;color:var(--accent2)}.dash-icon-community{background:#4ab5a01f;color:var(--teal)}.dash-icon-player{background:var(--nav-active-bg);color:var(--accent)}.dash-icon-admin{background:#e87b9e1f;color:var(--pink)}.dash-overview-value{font-size:22px;font-weight:700;line-height:1;margin-bottom:3px}.dash-overview-label{font-size:12px;color:var(--text3);display:flex;align-items:center;gap:6px}.dash-badge{display:inline-block;font-size:10px;padding:2px 7px;border-radius:10px;font-weight:600;letter-spacing:0;text-transform:none}.dash-badge-ok{background:var(--success-bg);color:var(--success-text)}.dash-badge-warn{background:var(--warning-bg);color:var(--warning-text)}.dash-badge-danger{background:var(--danger-bg);color:var(--danger-text)}.dash-perf-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.dash-perf-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}.dash-perf-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.dash-perf-header{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:10px}.dash-perf-value{font-size:24px;font-weight:700;margin-bottom:10px;line-height:1}.dash-perf-bar{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}.dash-perf-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.16,1,.3,1);min-width:2px}.dash-perf-fill-blue{background:var(--accent2)}.dash-perf-fill-teal{background:var(--teal)}.dash-perf-fill-pink{background:var(--pink)}.dash-perf-hint{font-size:11px;color:var(--text3);margin-top:6px}.dash-lower-grid{display:grid;grid-template-columns:1fr 340px;gap:16px;margin-bottom:20px}.dash-wl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);overflow:hidden}.dash-wl-header{padding:18px 20px 0}.dash-wl-title{font-size:14.5px;font-weight:600}.dash-wl-sub{font-size:12px;color:var(--text2);margin-top:2px}.dash-wl-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px 20px 20px}.dash-wl-item{text-align:center;padding:14px 10px;border-radius:var(--r-md);border:1px solid var(--border)}.dash-wl-num{font-size:22px;font-weight:700;line-height:1;margin-bottom:6px}.dash-wl-label{font-size:11px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}.dash-wl-pending{background:var(--info-bg);border-color:#5b8dd933}.dash-wl-pending .dash-wl-num{color:var(--accent2)}.dash-wl-approved{background:var(--success-bg);border-color:#4ab5a033}.dash-wl-approved .dash-wl-num{color:var(--teal)}.dash-wl-rejected{background:var(--danger-bg);border-color:#e8735a26}.dash-wl-rejected .dash-wl-num{color:var(--accent)}.dash-wl-revoked{background:var(--surface2);border-color:var(--border)}.dash-wl-revoked .dash-wl-num{color:var(--text3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:2000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;padding:24px}.modal-overlay.active{display:flex;opacity:1}.modal{background:var(--surface);width:100%;max-width:520px;border-radius:18px;box-shadow:0 8px 40px #00000026,0 0 0 1px var(--border);transform:scale(.95) translateY(12px);transition:transform .3s cubic-bezier(.16,1,.3,1);max-height:88vh;display:flex;flex-direction:column;overflow:hidden}.online-player-list{display:grid;gap:8px}.online-player-card{border:1px solid var(--border);border-radius:14px;padding:0;background:var(--surface);transition:all .2s ease;overflow:hidden}.online-player-card:hover{border-color:var(--border2);box-shadow:0 2px 12px #0000000a}.online-player-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px}.online-player-info{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.online-player-avatar{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--accent2),#7eb8ff);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}.online-player-detail{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.online-player-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.online-player-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.online-player-tag{font-size:11px;font-family:var(--mono);color:var(--text3);background:var(--surface2);padding:1px 7px;border-radius:6px;white-space:nowrap}.online-player-tag-tag-ping{color:var(--teal);background:#e1f5ee}.online-player-actions{display:flex;gap:6px;flex-shrink:0}.online-player-actions .btn-sm{padding:5px 12px;font-size:12px;border-radius:var(--r-sm)}.online-player-ban-form{margin:0;padding:14px 16px;background:var(--surface2);border-top:1px solid var(--border)}.ban-form-row{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.ban-form-field{display:flex;flex-direction:column;gap:4px}.ban-form-field label{font-size:11px;color:var(--text3);font-weight:500}.ban-form-field select{padding:6px 10px;font-size:13px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);min-width:100px}.ban-form-field select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px var(--focus-ring)}.online-player-action-form{margin:0;padding:10px 16px;background:var(--surface2);border-top:1px solid var(--border)}.action-form-input-row{display:flex;gap:8px;align-items:center}.action-form-input{flex:1;padding:7px 12px;font-size:13px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}.action-form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--focus-ring)}.action-form-input::placeholder{color:var(--text3)}.btn-sm{padding:6px 12px;font-size:13px}.online-player-header{padding:16px 16px 12px;display:flex;align-items:center;justify-content:space-between}.online-player-header-left{display:flex;align-items:center;gap:8px}.online-player-header-icon{width:20px;height:20px;color:var(--accent)}.online-player-count{font-size:12px;color:var(--text3);font-weight:500;background:var(--surface2);padding:3px 10px;border-radius:var(--r-xl)}.online-player-empty{text-align:center;padding:32px 16px;color:var(--text3)}.online-player-empty-icon{font-size:32px;margin-bottom:8px;opacity:.5}.online-player-empty-text{font-size:13px}.online-player-loading{text-align:center;padding:24px 16px;color:var(--text3)}.online-player-server{padding:12px 16px;background:var(--surface2);border-bottom:1px solid var(--border);border-radius:var(--r-lg) var(--r-lg) 0 0}.online-player-server-name{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.online-player-server-dot{width:8px;height:8px;border-radius:50%;background:var(--success-dot);display:inline-block}.row-global-ban{background:var(--danger-bg)!important}.row-global-ban:hover{background:var(--danger-bg-hover)!important}.nickname-cell{line-height:1.4}.global-ban-btn{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:600;border-radius:12px;background:var(--accent);color:#fff;border:none;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #e8735a4d}.global-ban-btn:hover{transform:scale(1.05);box-shadow:0 2px 6px #e8735a66}.global-ban-icon{font-size:12px}.global-ban-btn .global-ban-count{background:#ffffff4d;padding:1px 5px;border-radius:8px;font-size:10px}.global-ban-alert{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--danger-bg);border:1px solid var(--danger-text);border-radius:var(--r-md);margin-bottom:16px}.global-ban-alert-icon{font-size:24px;color:var(--danger-text);line-height:1}.global-ban-alert-text{font-size:13px;color:var(--text);line-height:1.5}.global-ban-alert-text strong{color:var(--danger-text)}.global-ban-info{margin-bottom:16px;font-size:13px}.global-ban-info code{background:var(--bg);padding:2px 8px;border-radius:4px;font-family:var(--mono);font-size:12px}.global-ban-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.global-ban-item{border:1px solid var(--border);border-radius:var(--r-md);padding:12px;background:var(--bg)}.global-ban-item-header{display:flex;gap:8px;margin-bottom:10px}.global-ban-type{font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px;background:var(--danger-bg);color:var(--danger-text)}.global-ban-permanent{font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px;background:var(--accent);color:#fff}.global-ban-temporary{font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px;background:var(--warning-bg);color:var(--warning-text)}.global-ban-item-body{font-size:12px;color:var(--text2);line-height:1.6}.global-ban-field{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}.global-ban-field:last-child{margin-bottom:0}.global-ban-label{font-size:10px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}.global-ban-value{color:var(--text);font-size:12px}.global-ban-stats{font-size:10px;word-break:break-all;color:var(--text2);font-family:var(--mono)}.global-ban-empty{padding:20px;text-align:center;color:var(--text3)}.modal-overlay.active .modal{transform:scale(1) translateY(0)}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--surface);z-index:10;flex-shrink:0}.modal-header h2,.modal-header h3{font-size:16px;font-weight:700;letter-spacing:-.2px}.modal-body{padding:20px 24px;overflow-y:auto;flex:1;min-height:0}.confirm-dialog-message{color:var(--text2);line-height:1.7;font-size:14px}.modal-footer{padding:14px 24px;background:color-mix(in srgb,var(--bg) 60%,transparent);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;position:sticky;bottom:0;flex-shrink:0}.form{display:grid;gap:12px;max-width:500px;margin:0 auto}.public-form{padding-top:8px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--text2);letter-spacing:.2px}.form-control,.form input,.form textarea,.form select{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-family:inherit;font-size:13.5px;outline:none;transition:border-color .2s,background .2s,box-shadow .2s;background:var(--surface);color:var(--text);line-height:1.5}.form-control::placeholder,.form input::placeholder,.form textarea::placeholder{color:var(--text3)}.form-control:focus,.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--accent);background:var(--focus-bg);box-shadow:0 0 0 3px var(--focus-ring),0 2px 8px #e8735a0f}.form-control:disabled,.form input:disabled,.form textarea:disabled,.form select:disabled{background:var(--surface2);color:var(--text3);cursor:not-allowed;opacity:.6}.form select,.form-control select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239e9b93' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}[data-theme=dark] .form select,[data-theme=dark] .form-control select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2381786f' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E")}.form select option,.form-control option{background-color:#fff;color:#1a1917}[data-theme=dark] .form select option,[data-theme=dark] .form-control option{background-color:#1a1816;color:#f2eee8}.form-row{display:flex;gap:12px;margin-bottom:0}.form-row>.form-group{flex:1}.form-section{margin:22px 0 14px;border-top:1px solid var(--border);padding-top:14px}.form-section:first-child{margin-top:0;border-top:none;padding-top:0}.form-section-title{font-size:12.5px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}.form-hint{font-size:12px;color:var(--text3);margin-top:6px;line-height:1.4}.form-section-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:14px;transition:border-color .2s}.form-section-card:last-child{margin-bottom:0}.form-section-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.form-section-header svg{width:16px;height:16px;color:var(--accent);flex-shrink:0}.form-section-card .form-group{margin-bottom:12px}.form-section-card .form-group:last-child{margin-bottom:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--text3)}.empty-state-icon{width:52px;height:52px;border-radius:14px;background:var(--surface2);display:flex;align-items:center;justify-content:center;margin-bottom:14px;color:var(--text3)}.empty-state-icon svg{width:24px;height:24px}.empty-state-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px}.empty-state-desc{font-size:13px;color:var(--text3);max-width:320px;line-height:1.5}.loading-state{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px 24px;color:var(--text3);font-size:13.5px}.loading-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0}.toggle-row+.toggle-row{border-top:1px solid var(--border)}.toggle-label{font-size:13px;font-weight:500;color:var(--text)}.toggle-desc{font-size:12px;color:var(--text3);margin-top:2px}.toggle-switch{position:relative;width:40px;height:22px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border2);border-radius:11px;cursor:pointer;transition:background var(--transition)}.toggle-slider:before{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:0 1px 3px #00000026}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.toggle-switch input:focus-visible+.toggle-slider{box-shadow:0 0 0 3px var(--focus-ring)}.action-btn-group{display:flex;align-items:center;gap:5px;justify-content:flex-end}.action-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;font-size:12px;font-weight:500;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;transition:all .18s ease;white-space:nowrap;line-height:1.4}.action-btn:hover{background:var(--surface2);color:var(--text);border-color:var(--border2);transform:translateY(-1px);box-shadow:0 2px 8px #0000000d}.action-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.action-btn:disabled:hover{box-shadow:none;transform:none}.action-btn svg{width:13px;height:13px;flex-shrink:0}.action-btn-danger{color:var(--danger-text)}.action-btn-danger:hover{background:var(--danger-bg);border-color:var(--danger-text);color:var(--danger-text);box-shadow:0 2px 8px #dc26261a}.action-btn-accent{color:var(--accent)}.action-btn-accent:hover{background:var(--nav-active-bg);border-color:var(--accent);color:var(--accent);box-shadow:0 2px 8px #e8735a1a}.action-btn-success{color:var(--teal)}.action-btn-success:hover{background:var(--success-bg);border-color:var(--teal);color:var(--teal);box-shadow:0 2px 8px #4ab5a01a}.token-display{display:flex;align-items:center;gap:6px}.token-text{font-family:var(--mono);font-size:12px;letter-spacing:.5px;color:var(--text3)}.token-text.revealed{color:var(--accent2)}.token-btn{border:none;background:none;color:var(--accent2);cursor:pointer;font-size:12px;font-weight:500;padding:2px 4px;transition:color var(--transition)}.token-btn:hover{color:var(--accent)}.token-btn-copy{color:var(--teal)}.token-btn-copy:hover{color:var(--accent)}.checkbox-group{display:flex;gap:10px;align-items:center}.checkbox-group label{margin-bottom:0;cursor:pointer}.form-hint{font-size:11.5px;color:var(--text3);margin-top:6px}.form-hint-loading{color:var(--accent2);margin-left:8px}.form-hint-warning{color:var(--warning-text)}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r-md);margin-bottom:12px}.alert-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.alert-content{flex:1;min-width:0}.alert-title{font-size:13px;font-weight:600;margin-bottom:2px}.alert-text{font-size:12px;line-height:1.5}.alert-error{background:var(--danger-bg);border:1px solid var(--danger-text)}.alert-error .alert-icon{background:var(--danger-text);color:#fff}.alert-error .alert-title,.alert-error .alert-text{color:var(--danger-text)}.alert-success{background:var(--success-bg);border:1px solid var(--success-text)}.alert-success .alert-icon{background:var(--success-text);color:#fff}.alert-success .alert-title,.alert-success .alert-text{color:var(--success-text)}.alert-warning{background:var(--warning-bg);border:1px solid var(--warning-text)}.alert-warning .alert-icon{background:var(--warning-text);color:#fff}.alert-warning .alert-title,.alert-warning .alert-text{color:var(--warning-text)}.alert-info{background:var(--info-bg);border:1px solid var(--info-text)}.alert-info .alert-icon{background:var(--info-text);color:#fff}.alert-info .alert-title,.alert-info .alert-text{color:var(--info-text)}.success-note{color:var(--teal);font-size:13px}.search-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.search-bar-input{max-width:400px;border-radius:12px!important;transition:all .2s ease;height:40px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13.5px;padding:0 14px;outline:none}.search-bar-input::placeholder{color:var(--text3)}.search-bar-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring),0 2px 8px #e8735a0f}.search-bar-select{max-width:160px;padding:10px 32px 10px 14px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;transition:all .2s;font-size:13px;outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239e9b93' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;height:40px}.search-bar-select:hover{border-color:var(--border2)}.search-bar-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring)}.search-bar-select option{background-color:#fff;color:#1a1917}[data-theme=dark] .search-bar-select option{background-color:#1a1816;color:#f2eee8}[data-theme=dark] .search-bar-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2381786f' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E")}.pagination{display:flex;align-items:center;gap:4px;margin-top:18px;flex-wrap:wrap;padding:4px 0}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled):not(.is-active){background:var(--surface2);border-color:var(--accent);color:var(--accent);transform:translateY(-1px);box-shadow:0 2px 8px #e8735a1a}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-btn.is-active{background:linear-gradient(135deg,var(--accent),#f08a6a);color:#fff;border-color:transparent;box-shadow:0 2px 10px #e8735a4d;font-weight:600}.pagination-ellipsis{color:var(--text3);font-size:12px;padding:0 6px}.pagination-info{margin-left:auto;font-size:12.5px;color:var(--text3)}.public-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text)}.public-nav{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.public-nav-inner{max-width:960px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;gap:20px}.public-brand{display:flex;align-items:center;gap:9px;cursor:pointer;flex-shrink:0}.public-brand-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),#f0a07a);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}.public-brand-text{font-size:15px;font-weight:600;letter-spacing:-.3px}.public-nav-links{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}.public-nav-link{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-md);font-size:13px;font-weight:500;color:var(--text2);background:transparent;border:none;cursor:pointer;transition:all var(--transition)}.public-nav-link:hover{background:var(--surface2);color:var(--text)}.public-nav-link.active{background:var(--nav-active-bg);color:var(--accent);font-weight:600}.public-nav-link svg{width:15px;height:15px;flex-shrink:0}.public-nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.public-main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:32px 24px 48px}.public-footer{text-align:center;padding:20px 24px;font-size:12px;color:var(--text3);border-top:1px solid var(--border);background:var(--surface)}.public-hero{text-align:center;margin-bottom:32px;padding:12px 0 0}.public-hero-icon{width:48px;height:48px;margin:0 auto 14px;background:linear-gradient(135deg,var(--accent),#f0a07a);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #e8735a33}.public-hero-icon svg{width:24px;height:24px;color:#fff}.public-hero h1{font-size:22px;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}.public-hero p{font-size:14px;color:var(--text2);max-width:460px;margin:0 auto;line-height:1.6}.public-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);overflow:hidden}.public-card-body{padding:24px}.public-stats{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.public-stat{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);font-size:13px}.public-stat-value{font-weight:600;font-size:16px}.public-stat-label{color:var(--text3);font-size:12px}.public-table{width:100%;border-collapse:collapse;font-size:13px}.public-table th{text-align:left;padding:12px 16px;font-size:11.5px;font-weight:500;color:var(--text3);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.public-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.public-table tbody tr{transition:background var(--transition)}.public-table tbody tr:hover{background:var(--bg)}.public-table tbody tr:last-child td{border-bottom:none}.public-empty{text-align:center;padding:48px 20px;color:var(--text3)}.public-empty svg{width:40px;height:40px;color:var(--text3);opacity:.5;margin-bottom:12px}.public-empty-text{font-size:14px;margin-bottom:4px}.public-empty-hint{font-size:12px;color:var(--text3)}.public-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:48px 20px;color:var(--text3);font-size:13px}.public-loading-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:public-spin .7s linear infinite}@keyframes public-spin{to{transform:rotate(360deg)}}.public-error{text-align:center;padding:32px 20px;color:var(--danger-text);font-size:13px}.public-error-retry{margin-top:12px;display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:13px;cursor:pointer;transition:all var(--transition)}.public-error-retry:hover{background:var(--surface2);border-color:var(--accent);color:var(--accent)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}@media(max-width:1200px){.metrics-grid,.metric-grid,.dash-overview,.dash-perf-grid{grid-template-columns:repeat(2,1fr)}.dash-lower-grid,.lower-grid{grid-template-columns:1fr}}.toast-container{position:fixed;top:20px;right:20px;z-index:3000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast-item{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;padding:14px 18px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border);box-shadow:0 4px 20px #0000001f;min-width:280px;max-width:400px;animation:toast-in .35s cubic-bezier(.16,1,.3,1)}.toast-item.toast-exiting{animation:toast-out .3s ease forwards}.toast-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}.toast-success .toast-icon{background:var(--success-bg);color:var(--success-text)}.toast-danger .toast-icon{background:var(--danger-bg);color:var(--danger-text)}.toast-success{border-left:3px solid var(--success-dot)}.toast-danger{border-left:3px solid var(--danger-dot)}.toast-content{flex:1;min-width:0}.toast-title{font-size:13.5px;font-weight:600;color:var(--text)}.toast-message{font-size:12.5px;color:var(--text2);margin-top:3px;line-height:1.5}.toast-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:13px;padding:0;line-height:1;flex-shrink:0;margin-top:1px}.toast-close:hover{color:var(--text)}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.login-bg-shapes{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.login-shape{position:absolute;border-radius:50%;opacity:.5;animation:login-float 20s ease-in-out infinite}.login-shape-1{width:500px;height:500px;background:radial-gradient(circle,rgba(232,115,90,.12) 0%,transparent 70%);top:-150px;right:-100px;animation-delay:0s}.login-shape-2{width:400px;height:400px;background:radial-gradient(circle,rgba(91,141,217,.1) 0%,transparent 70%);bottom:-100px;left:-80px;animation-delay:-7s}.login-shape-3{width:300px;height:300px;background:radial-gradient(circle,rgba(74,181,160,.1) 0%,transparent 70%);top:40%;left:60%;animation-delay:-14s}@keyframes login-float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-20px) scale(1.05)}50%{transform:translate(-20px,30px) scale(.95)}75%{transform:translate(15px,15px) scale(1.02)}}.login-container{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;width:100%;max-width:420px;padding:24px;animation:login-appear .6s cubic-bezier(.16,1,.3,1)}@keyframes login-appear{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),#f0a07a);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #e8735a40}.login-brand-text{font-size:20px;font-weight:700;letter-spacing:-.5px;color:var(--text)}.login-card{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-md);overflow:hidden}.login-card-header{padding:28px 28px 0;text-align:center}.login-card-title{font-size:18px;font-weight:700;letter-spacing:-.3px;margin:0;color:var(--text)}.login-card-sub{font-size:13px;color:var(--text2);margin-top:6px}.login-card-body{padding:24px 28px 28px;display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:8px}.login-label{font-size:12.5px;font-weight:600;color:var(--text2);letter-spacing:.3px}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:14px;color:var(--text3);pointer-events:none;transition:color var(--transition)}.login-input{width:100%;padding:12px 14px 12px 42px;border:1px solid var(--border);border-radius:var(--r-lg);font-family:inherit;font-size:14px;background:var(--bg);color:var(--text);outline:none;transition:all var(--transition)}.login-input::placeholder{color:var(--text3)}.login-input:focus{border-color:var(--accent);background:var(--focus-bg);box-shadow:0 0 0 3px var(--focus-ring),0 2px 8px #e8735a14}.login-input:focus+.login-input-icon,.login-input:focus~.login-input-icon{color:var(--accent)}.login-btn{width:100%;padding:13px 24px;margin-top:4px;border:none;border-radius:var(--r-lg);font-family:inherit;font-size:15px;font-weight:600;letter-spacing:2px;cursor:pointer;background:linear-gradient(135deg,var(--accent),#f0a07a);color:#fff;box-shadow:0 4px 16px #e8735a4d;transition:all var(--transition);position:relative;overflow:hidden}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #e8735a66}.login-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #e8735a4d}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn-loading{display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:0}.login-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:login-spin .6s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}.login-footer{margin-top:28px;font-size:12px;color:var(--text3);letter-spacing:.5px}.login-error-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:login-error-in .2s ease}.login-error-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-md);padding:32px 28px 24px;max-width:360px;width:100%;text-align:center;animation:login-error-scale .3s cubic-bezier(.16,1,.3,1)}@keyframes login-error-in{0%{opacity:0}to{opacity:1}}@keyframes login-error-scale{0%{transform:scale(.9) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.login-error-icon{width:56px;height:56px;margin:0 auto 18px;background:var(--danger-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--danger-dot)}.login-error-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px}.login-error-message{font-size:13.5px;color:var(--text2);line-height:1.6;margin-bottom:24px}.login-error-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 32px;border:none;border-radius:var(--r-lg);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;background:var(--text);color:var(--surface);transition:all var(--transition)}.login-error-btn:hover{opacity:.85;transform:translateY(-1px)}@media(max-width:480px){.login-container{padding:16px}.login-card-header{padding:24px 20px 0}.login-card-body{padding:20px 20px 24px}}@media(max-width:768px){.sidebar{width:var(--sidebar-collapsed)}.sidebar .nav-text,.sidebar-footer .nav-text,.sidebar-footer .user-info,.logout-text{display:none!important}.sidebar-logo .logo-text,.brand-text{opacity:0;width:0;display:none}.sidebar-collapse-btn{display:none}.main,.app-main{margin-left:var(--sidebar-collapsed)}.topbar{padding:0 16px;gap:12px}.content-section,.page{padding:20px 16px}.metrics-grid,.metric-grid{grid-template-columns:1fr;gap:12px}.dash-overview,.dash-perf-grid{grid-template-columns:1fr;gap:10px}.dash-hero{flex-direction:column;align-items:flex-start;gap:12px;padding:20px}.dash-hero-title{font-size:18px}.search-shortcut,.searchbar span{display:none}.icon-btn:not(.notif-btn){display:none}.public-nav-inner{padding:0 14px;gap:8px}.public-nav-link span{display:none}.public-main{padding:20px 14px 36px}.public-hero h1{font-size:18px}.public-stats{gap:8px}.public-stat{padding:6px 10px;font-size:12px}.public-table th,.public-table td{padding:10px}}.notification-bell,.notification-toggle{position:relative}.notification-badge{position:absolute;top:-4px;right:-6px;background:var(--danger-dot);color:#fff;font-size:10px;font-weight:600;line-height:1;min-width:16px;height:16px;padding:0 4px;border-radius:8px;display:flex;align-items:center;justify-content:center;pointer-events:none}.notification-panel{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-height:480px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-md);z-index:100;display:flex;flex-direction:column;overflow:hidden}.notification-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);font-weight:600;font-size:14px;color:var(--text)}.notification-mark-all{background:none;border:none;color:var(--accent2);font-size:12px;cursor:pointer;padding:2px 6px;border-radius:4px}.notification-mark-all:hover{background:var(--surface2)}.notification-panel-body{overflow-y:auto;flex:1;max-height:420px}.notification-panel-footer{border-top:1px solid var(--border);padding:8px}.notification-view-all{display:block;width:100%;padding:8px;text-align:center;font-size:13px;color:var(--accent2);background:none;border:none;border-radius:6px;cursor:pointer}.notification-view-all:hover{background:var(--surface2)}.notification-empty{padding:32px 16px;text-align:center;color:var(--text3);font-size:13px}.notification-item{display:flex;gap:12px;padding:12px 16px;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;position:relative;color:var(--text)}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--surface2)}.notification-item.unread{background:var(--info-bg)}.notification-item-icon{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--surface2);color:var(--text2)}.notification-item-content{flex:1;min-width:0}.notification-item-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}.notification-item-message{font-size:12px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-item-time{font-size:11px;color:var(--text3);margin-top:4px}.notification-item-dot{position:absolute;top:16px;right:16px;width:8px;height:8px;border-radius:50%;background:var(--accent2)}.notification-page-list{display:flex;flex-direction:column}.notification-page-item{display:flex;gap:16px;padding:16px 20px;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;position:relative;color:var(--text)}.notification-page-item:last-child{border-bottom:none}.notification-page-item:hover{background:var(--surface2)}.notification-page-item.unread{background:var(--info-bg);border-left:3px solid var(--accent2)}.notification-page-item-icon{flex-shrink:0;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--surface2);color:var(--text2)}.notification-page-item-body{flex:1;min-width:0}.notification-page-item-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:8px}.notification-page-item-tags{display:flex;align-items:center;gap:6px}.notification-page-item-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.notification-page-item-message{font-size:13px;color:var(--text2);line-height:1.4}.notification-page-item-time{font-size:12px;color:var(--text3);white-space:nowrap}.ban-appeal-record{display:flex;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;transition:all .15s;background:var(--surface)}.ban-appeal-record:hover{border-color:var(--accent2);background:var(--surface2)}.ban-appeal-record.selected{border-color:var(--accent2);background:var(--info-bg);box-shadow:0 0 0 1px var(--accent2)}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}:root{--skeleton-bg: #e8e8e8}[data-theme=dark]{--skeleton-bg: #333}
