@import"https://fonts.googleapis.com/css2?family=Ubuntu+Sans:ital,wght@0,100..800;1,100..800&display=swap";:root{--primary-color: #fede54;--primary-rgb: 254, 222, 84;--primary-dim: #bfa100;--bg-card: rgba(40, 40, 40, .92);--bg-overlay: rgba(0, 0, 0, .7);--border-color: #333;--text-primary: #ffffff;--text-secondary: #c0c0c0;--error-color: #ff6b6b;--success-color: #4caf50}*{margin:0;padding:0;box-sizing:border-box;outline:none}html,body{font-family:Ubuntu Sans,sans-serif;height:100%;background:#111;color:var(--text-primary)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0000004d;border-radius:4px}::-webkit-scrollbar-thumb{background:#555;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#777}button,img{-webkit-user-select:none;user-select:none}button{cursor:pointer;font-family:inherit;border:none;transition:filter .15s ease}button:hover{filter:brightness(1.12)}button:active{filter:brightness(.92)}.dirt-background{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background-image:url(/dirt0.svg),url(/dirt1.svg);background-size:100px 100px,100px 100px;background-position:0 0,50px 50px;background-repeat:repeat}.outlined-text{color:#fff;paint-order:stroke fill;-webkit-text-stroke:.08em black}.section-container{background-color:var(--bg-card);border:3px solid var(--border-color);border-radius:12px;padding:20px}.section-title{color:#fff;paint-order:stroke fill;-webkit-text-stroke:.08em black;font-size:22px;font-weight:700;margin-bottom:14px}.stat-value{font-size:52px;font-weight:800;color:var(--primary-color);paint-order:stroke fill;-webkit-text-stroke:.04em black;line-height:1}.stat-label{font-size:14px;color:var(--text-secondary);margin-top:6px;letter-spacing:.05em;text-transform:uppercase}.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:440px;display:flex;flex-direction:column;gap:20px}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:4px}.login-logo-text{font-size:28px;font-weight:800;color:var(--primary-color)}.login-badge{background:var(--primary-color);color:#111;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:6px;border:2px solid var(--primary-dim);align-self:center}.login-subtitle{color:var(--text-secondary);font-size:14px;margin-top:-8px}.login-field{display:flex;flex-direction:column;gap:7px}.login-label{font-size:13px;font-weight:600;color:#bbb;text-transform:uppercase;letter-spacing:.06em}.login-input{background:#00000080;border:2px solid #444;border-radius:8px;padding:11px 14px;font-family:Courier New,monospace;font-size:14px;color:#fff;width:100%;transition:border-color .2s}.login-input:focus{border-color:var(--primary-color)}.login-input::placeholder{color:#666}.login-input:disabled{opacity:.6}.login-error{background:#ff6b6b1a;border:2px solid #ff6b6b;border-radius:8px;color:#ff6b6b;font-size:14px;padding:10px 14px}.login-btn{background:var(--primary-color);color:#111;border:2px solid var(--primary-dim);border-radius:8px;padding:12px 20px;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:10px;width:100%}.login-btn:disabled{opacity:.7;cursor:not-allowed;filter:none}.login-spinner{width:16px;height:16px;border:3px solid rgba(0,0,0,.2);border-top-color:#111;border-radius:50%;animation:login-spin .7s linear infinite;display:inline-block}@keyframes login-spin{to{transform:rotate(360deg)}}.login-hint{font-size:13px;color:#666;text-align:center}.login-hint code{color:var(--primary-color);font-size:12px;background:#fede541a;padding:1px 6px;border-radius:4px}.session-timer{display:flex;align-items:center;gap:8px;background:#0006;border:2px solid #444;border-radius:8px;padding:5px 14px;font-size:15px;font-weight:600}.session-timer__label{color:#aaa;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.session-timer__value{color:var(--primary-color);font-variant-numeric:tabular-nums;font-size:16px;font-weight:700;letter-spacing:.04em}.session-timer--urgent .session-timer__value{color:#ff6b6b;animation:pulse-urgent 1s ease-in-out infinite}@keyframes pulse-urgent{0%,to{opacity:1}50%{opacity:.6}}.admin-layout{display:flex;min-height:100vh;gap:0}.admin-sidebar{width:220px;min-width:220px;display:flex;flex-direction:column;gap:0;padding:20px 0;border-radius:0;border-top:none;border-bottom:none;border-left:none;position:sticky;top:0;height:100vh;z-index:10}.sidebar-brand{display:flex;align-items:center;gap:8px;padding:0 16px 20px;border-bottom:1px solid var(--border-color);margin-bottom:10px}.sidebar-logo{font-size:16px;font-weight:800;color:var(--primary-color);white-space:nowrap}.sidebar-badge{background:var(--primary-color);color:#111;font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border-radius:4px;border:2px solid var(--primary-dim);flex-shrink:0}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 8px}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:14px;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:background .15s,color .15s}.sidebar-nav-item:hover{background:#ffffff0f;color:var(--text-primary)}.sidebar-nav-item.active{background:#fede541f;color:var(--primary-color)}.sidebar-nav-icon{display:flex;align-items:center;opacity:.8}.sidebar-nav-item.active .sidebar-nav-icon{opacity:1}.sidebar-logout-btn{margin:10px 8px 0;display:flex;align-items:center;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.4);border-radius:8px;color:#ff6b6b;font-size:13px;font-weight:700;padding:9px 12px}.admin-content{flex:1;display:flex;flex-direction:column;min-width:0;padding:16px;gap:16px}.admin-topbar{display:flex;align-items:center;justify-content:flex-end;gap:14px;padding:10px 16px;flex-shrink:0}.admin-main{flex:1;min-height:0}@media(max-width:700px){.admin-sidebar{display:none}.admin-content{padding:10px}}.dashboard-page{display:flex;flex-direction:column;gap:20px}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.stat-card{display:flex;align-items:center;gap:16px;padding:20px}.stat-card__icon{color:var(--primary-color);flex-shrink:0;opacity:.9}.stat-card__body{display:flex;flex-direction:column;gap:3px;min-width:0}.dashboard-chart{padding:20px 20px 12px}.broadcast-panel{display:flex;flex-direction:column;gap:14px;padding:20px}.broadcast-hint{font-size:13px;color:var(--text-secondary);margin-top:-8px}.broadcast-textarea{background:#0000004d;border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;padding:10px 12px;resize:vertical;min-height:80px;transition:border-color .15s}.broadcast-textarea:focus{border-color:var(--primary-dim)}.broadcast-options{display:flex;flex-direction:column;gap:8px}.broadcast-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.broadcast-toggle input[type=checkbox]{accent-color:var(--primary-color);width:15px;height:15px;cursor:pointer}.broadcast-feedback{font-size:13px;font-weight:600;padding:8px 12px;border-radius:6px}.broadcast-feedback.ok{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.broadcast-feedback.error{background:#ff6b6b26;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.broadcast-btn{background:var(--primary-color);color:#111;font-size:14px;font-weight:800;padding:10px 20px;border-radius:8px;align-self:flex-start;display:flex;align-items:center;gap:8px}.broadcast-btn:disabled{opacity:.5;cursor:not-allowed}.login-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,0,0,.3);border-top-color:#111;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:600px){.dashboard-stats-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;padding:14px 20px}.dashboard-brand{display:flex;align-items:center;gap:10px}.dashboard-logo{font-size:24px;font-weight:800;color:var(--primary-color)}.dashboard-badge{background:var(--primary-color);color:#111;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:5px;border:2px solid var(--primary-dim)}.dashboard-topbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ws-indicator{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:#aaa}.ws-dot{width:9px;height:9px;border-radius:50%;background:#555;flex-shrink:0}.ws-indicator--open .ws-dot{background:#4caf50;box-shadow:0 0 6px #4caf50}.ws-indicator--open{color:#4caf50}.ws-indicator--connecting .ws-dot{background:var(--primary-color);animation:blink-dot 1s ease-in-out infinite}.ws-indicator--connecting{color:var(--primary-color)}.ws-indicator--closed .ws-dot{background:#ff6b6b;animation:blink-dot .8s ease-in-out infinite}.ws-indicator--closed{color:#ff6b6b}@keyframes blink-dot{0%,to{opacity:1}50%{opacity:.3}}.dashboard-logout-btn{background:#ff6b6b26;border:2px solid #ff6b6b;border-radius:7px;color:#ff6b6b;font-size:13px;font-weight:700;padding:6px 14px}.dashboard-main{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;align-content:start}.stat-card{display:flex;align-items:center;gap:18px;padding:24px}.stat-card__icon{color:var(--primary-color);flex-shrink:0;opacity:.85}.stat-card__body{display:flex;flex-direction:column;gap:4px}@media(max-width:600px){.dashboard-root{padding:12px}.dashboard-topbar{flex-direction:column;align-items:flex-start}.dashboard-topbar-right{width:100%;justify-content:space-between}}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:100;display:flex;justify-content:flex-end;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.drawer-panel{width:420px;max-width:95vw;height:100vh;overflow-y:auto;display:flex;flex-direction:column;gap:16px;padding:22px;border-radius:0;border-top:none;border-bottom:none;border-right:none;animation:slide-in .2s ease}@keyframes slide-in{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.drawer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.drawer-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.drawer-username{font-size:18px;font-weight:800;color:var(--text-primary)}.drawer-auth-badge{background:#fede5426;color:var(--primary-color);font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px;border:1px solid rgba(254,222,84,.3);text-transform:uppercase;letter-spacing:.06em}.drawer-close{background:#ffffff14;border:1px solid #444;border-radius:6px;color:#aaa;font-size:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.drawer-info{display:flex;flex-direction:column;gap:0;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.drawer-row{display:flex;align-items:flex-start;gap:8px;padding:9px 12px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05)}.drawer-row:last-child{border-bottom:none}.drawer-row:nth-child(odd){background:#ffffff08}.drawer-row__label{color:var(--text-secondary);min-width:100px;flex-shrink:0}.drawer-row__value{color:var(--text-primary);word-break:break-all}.drawer-code{font-family:monospace;font-size:12px;background:#0000004d;padding:1px 5px;border-radius:4px;color:#aaf}.drawer-ua{font-size:11px;color:#888;font-family:monospace}.drawer-muted{color:#ff6b6b;font-weight:600}.drawer-role{font-weight:700;text-transform:capitalize}.drawer-role.role-owner{color:#f44}.drawer-role.role-admin{color:#ff8c00}.drawer-role.role-moderator{color:#64b5f6}.drawer-role.role-special{color:#ab47bc}.drawer-role.role-donator{color:#ffa726}.drawer-role.role-user{color:#81c784}.drawer-role.role-guest{color:#aaa}.drawer-feedback{font-size:13px;font-weight:600;padding:8px 12px;border-radius:6px}.drawer-feedback.ok{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.drawer-feedback.error{background:#ff6b6b26;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.drawer-actions{display:flex;flex-direction:column;gap:8px}.drawer-action-btn{padding:9px 14px;border-radius:7px;font-size:13px;font-weight:700;border:2px solid;text-align:left}.drawer-action-btn.mute{background:#ffb74d1f;border-color:#ffb74d;color:#ffb74d}.drawer-action-btn.kick{background:#64b5f61f;border-color:#64b5f6;color:#64b5f6}.drawer-action-btn.ban{background:#ff6b6b1f;border-color:#ff6b6b;color:#ff6b6b}.drawer-action-btn.confirm{background:#fede5426;border-color:var(--primary-color);color:var(--primary-color)}.drawer-action-btn.cancel{background:#ffffff0d;border-color:#555;color:#aaa}.drawer-action-btn:disabled{opacity:.4;cursor:not-allowed}.drawer-subform{background:#0003;border:1px solid var(--border-color);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:6px}.drawer-subform-label{font-size:12px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.drawer-select,.drawer-input{background:#0000004d;border:1px solid #444;border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:13px;padding:7px 10px;width:100%}.drawer-subform-btns{display:flex;gap:8px;margin-top:4px}.drawer-subform-btns .drawer-action-btn{flex:1;text-align:center}.drawer-section{display:flex;flex-direction:column;gap:8px}.drawer-section-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);padding-bottom:4px;border-bottom:1px solid var(--border-color)}.drawer-loading{font-size:12px;color:#888;padding:8px 0}.drawer-ip-list{display:flex;flex-wrap:wrap;gap:4px}.drawer-ip-checkboxes{display:flex;flex-direction:column;gap:5px;max-height:120px;overflow-y:auto;padding:6px 8px;background:#0003;border:1px solid var(--border-color);border-radius:6px}.drawer-checkbox-row{display:flex;align-items:center;gap:8px;font-size:12px;cursor:pointer;color:var(--text-primary)}.drawer-checkbox-row input[type=checkbox]{accent-color:var(--primary-color);cursor:pointer}.drawer-current-tag{font-size:10px;font-weight:700;color:var(--primary-color);background:#fede541f;border:1px solid rgba(254,222,84,.3);border-radius:4px;padding:1px 5px;text-transform:uppercase}.drawer-radio-group{display:flex;flex-direction:column;gap:5px}.drawer-radio{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-primary);cursor:pointer}.drawer-radio input[type=radio]{accent-color:var(--primary-color);cursor:pointer}.drawer-color-row{display:flex;align-items:center;gap:8px}.drawer-color-picker{width:36px;height:34px;padding:2px;border:1px solid #444;border-radius:6px;background:#0000004d;cursor:pointer;flex-shrink:0}.drawer-color-swatch{display:inline-block;width:10px;height:10px;border-radius:50%;margin-left:5px;vertical-align:middle;border:1px solid rgba(255,255,255,.2)}.drawer-textarea{resize:vertical;font-family:monospace;font-size:12px;min-height:80px}.drawer-action-btn.edit{background:#81c7841a;border-color:#81c784;color:#81c784}.drawer-action-btn.packet{background:#ab47bc1a;border-color:#ab47bc;color:#ab47bc}.clients-page,.muted-page,.bans-page{display:flex;flex-direction:column;gap:14px;height:100%}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.page-header-left{display:flex;align-items:center;gap:10px}.page-title{font-size:22px;font-weight:800;color:var(--text-primary);paint-order:stroke fill;-webkit-text-stroke:.04em black}.page-count{font-size:13px;color:var(--text-secondary);background:#ffffff12;padding:3px 9px;border-radius:20px;font-weight:600}.page-header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.page-search{background:#0000004d;border:1.5px solid #444;border-radius:7px;color:var(--text-primary);font-family:inherit;font-size:13px;padding:6px 12px;width:200px;transition:border-color .15s}.page-search:focus{border-color:var(--primary-dim)}.page-refresh-btn{display:flex;align-items:center;gap:6px;background:#fede541a;border:1.5px solid var(--primary-dim);border-radius:7px;color:var(--primary-color);font-size:13px;font-weight:700;padding:6px 12px}.filter-tabs{display:flex;gap:6px;flex-wrap:wrap}.filter-tab{background:#ffffff0d;border:1.5px solid #444;border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:600;padding:5px 12px;transition:all .15s}.filter-tab:hover{border-color:#666;color:var(--text-primary)}.filter-tab.active{background:#fede541f;border-color:var(--primary-color);color:var(--primary-color)}.page-error{padding:16px;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:8px;color:#ff6b6b;font-size:14px}.grid-loading,.grid-empty{color:var(--text-secondary);font-size:14px;padding:20px}.ag-cell{padding-left:12px;padding-right:12px}.clients-row{cursor:pointer}.badge{display:inline-flex;align-items:center;line-height:1;font-size:11px;font-weight:700;padding:3px 8px;border-radius:5px;border:1px solid;white-space:nowrap;text-transform:capitalize}.badge--ok{color:#4caf50;border-color:#4caf5059;background:#4caf501a}.badge--warn{color:#ffb74d;border-color:#ffb74d59;background:#ffb74d1a}.badge--danger{color:#ff6b6b;border-color:#ff6b6b59;background:#ff6b6b1a}.badge--info{color:#64b5f6;border-color:#64b5f659;background:#64b5f61a}.badge--dim{color:#888;border-color:#444;background:#ffffff0a}.badge--role-owner{color:#f44;border-color:#ff444459;background:#ff44441a}.badge--role-admin{color:#ff8c00;border-color:#ff8c0059;background:#ff8c001a}.badge--role-mod{color:#64b5f6;border-color:#64b5f659;background:#64b5f61a}.badge--role-special{color:#ab47bc;border-color:#ab47bc59;background:#ab47bc1a}.badge--role-donator{color:#ffa726;border-color:#ffa72659;background:#ffa7261a}.table-action-btn{font-size:12px;font-weight:700;padding:4px 12px;border-radius:5px;border:1.5px solid;cursor:pointer}.table-action-btn.unmute{background:#4caf501f;border-color:#4caf50;color:#4caf50}.table-action-btn.unban{background:#64b5f61f;border-color:#64b5f6;color:#64b5f6}.table-action-btn:disabled{opacity:.4;cursor:not-allowed}.page-feedback{padding:10px 14px;border-radius:7px;font-size:13px;font-weight:600}.page-feedback.ok{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.page-feedback.error{background:#ff6b6b26;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.add-ban-form{display:flex;flex-direction:column;gap:12px;padding:18px}.add-ban-title{font-size:15px;font-weight:700;color:var(--text-primary)}.add-ban-fields{display:flex;gap:12px;flex-wrap:wrap}.add-ban-field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:160px}.add-ban-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.drawer-input,.drawer-select{background:#0000004d;border:1px solid #444;border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:13px;padding:7px 10px;width:100%}
