@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{color-scheme:dark;--midnight: #0a181f;--accent: #00c77f;--accent-hover: #34d399;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--slate-950: #020617;--bg-body: var(--midnight);--bg-card: rgba(15, 23, 42, .6);--bg-card-solid: rgba(15, 23, 42, .7);--bg-input: var(--slate-900);--border: var(--slate-800);--border-hover: var(--slate-700);--text-primary: #fff;--text-secondary: var(--slate-300);--text-muted: var(--slate-400);--text-faint: var(--slate-500);--text-divider: var(--slate-600);--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--role-l0-from: rgba(168, 85, 247, .2);--role-l0-to: rgba(236, 72, 153, .2);--role-l0-border: rgba(168, 85, 247, .4);--role-l0-text: #c4b5fd;--role-l1-from: rgba(245, 158, 11, .2);--role-l1-to: rgba(249, 115, 22, .2);--role-l1-border: rgba(245, 158, 11, .4);--role-l1-text: #fcd34d;--role-l2-from: rgba(59, 130, 246, .2);--role-l2-to: rgba(6, 182, 212, .2);--role-l2-border: rgba(59, 130, 246, .4);--role-l2-text: #93c5fd;--container: 1200px;--radius-xl: 12px;--radius-md: 6px;--radius-full: 9999px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-body);color:var(--slate-100);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--slate-700);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--slate-600)}button:disabled{opacity:.5;cursor:not-allowed}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.app-root{min-height:100vh;display:flex;flex-direction:column}.app-header{border-bottom:1px solid var(--border);background:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:100}.app-header-inner{max-width:var(--container);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.app-header-left{display:flex;align-items:center;gap:32px}.logo{font-weight:700;font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.main-nav{display:flex;gap:24px}.nav-link{position:relative;font-size:.82rem;font-weight:500;color:var(--text-muted);text-decoration:none;padding-bottom:4px;transition:color .2s ease}.nav-link:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after{transform:scaleX(1)}.nav-link-active{color:var(--accent)}.nav-link-active:after{transform:scaleX(1)}.nav-dropdown{position:relative}.nav-drop-trigger{border:none;background:transparent;cursor:pointer;font-family:inherit}.nav-drop-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:180px;border-radius:var(--radius-md);border:1px solid var(--slate-700);background:var(--slate-900);box-shadow:0 12px 32px #00000080;padding:6px 0;z-index:150}.nav-drop-item{display:block;padding:8px 16px;font-size:.78rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all .15s ease}.nav-drop-item:hover{background:#00c77f0f;color:var(--text-primary)}.nav-drop-item-active{color:var(--accent)}.drop-enter-active,.drop-leave-active{transition:opacity .15s ease,transform .15s ease}.drop-enter-from,.drop-leave-to{opacity:0;transform:translateY(-6px)}.app-header-right{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:10px}.user-name{font-size:.82rem;font-weight:500;color:var(--text-secondary)}.app-main{flex:1;max-width:var(--container);width:100%;margin:0 auto;padding:32px 24px}.app-main-full{max-width:none;padding:0}.page-card{border-radius:var(--radius-xl);padding:24px;border:1px solid var(--border);background:var(--bg-card);opacity:0;animation:fadeInUp .5s ease-out forwards;transition:border-color .5s ease,box-shadow .5s ease}.page-title{font-size:1.5rem;font-weight:700;margin:0 0 4px;color:var(--text-primary)}.page-subtitle{margin:0 0 20px;font-size:.85rem;color:var(--text-muted)}.btn-primary{padding:8px 16px;border-radius:var(--radius-md);border:none;background:var(--accent);color:var(--midnight);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 8px 24px #00c77f40;transform:scale(1.02)}.btn-secondary{padding:6px 12px;border-radius:var(--radius-md);border:1px solid var(--slate-600);background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-small{padding:4px 10px;font-size:.72rem}.text-input{width:100%;padding:8px 12px;border-radius:var(--radius-md);border:1px solid var(--slate-700);background:var(--bg-input);color:var(--text-primary);font-family:inherit;font-size:.82rem;outline:none;transition:border-color .2s ease}.text-input::placeholder{color:var(--text-faint)}.text-input:focus{border-color:var(--accent)}textarea.text-input,.text-input.textarea{resize:vertical;min-height:64px;font-family:inherit;line-height:1.5}select.text-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}select.text-input option{background:var(--slate-900);color:var(--text-primary)}.field{display:flex;flex-direction:column;gap:4px}.field-label{font-size:.7rem;text-transform:uppercase;color:var(--text-muted);font-weight:500;letter-spacing:.04em}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.check-form{display:flex;flex-direction:column;gap:16px}.filter-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;align-items:flex-end}.filter-bar .field{min-width:150px}.wl-filters{margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.wl-tabs{display:flex;flex-wrap:wrap;gap:8px}.wl-tab{padding:6px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s ease}.wl-tab:hover{color:var(--text-primary);border-color:var(--border-hover)}.wl-tab-active{color:var(--accent);border-color:var(--accent);background:#00c77f0d}.role-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid}.role-l0{background:linear-gradient(to right,var(--role-l0-from),var(--role-l0-to));border-color:var(--role-l0-border);color:var(--role-l0-text)}.role-l1{background:linear-gradient(to right,var(--role-l1-from),var(--role-l1-to));border-color:var(--role-l1-border);color:var(--role-l1-text)}.role-l2{background:linear-gradient(to right,var(--role-l2-from),var(--role-l2-to));border-color:var(--role-l2-border);color:var(--role-l2-text)}.priority-pill,.status-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-md);font-size:.7rem;font-weight:600;border:1px solid}.priority-high{background:#ef44441a;border-color:#ef444466;color:#fca5a5}.priority-medium{background:#f59e0b1a;border-color:#f59e0b66;color:#fcd34d}.priority-low{background:#3b82f61a;border-color:#3b82f666;color:#93c5fd}.status-clean{background:#10b9811a;border-color:#10b98166;color:#6ee7b7}.status-punished{background:#ef44441a;border-color:#ef444466;color:#fca5a5}.status-warned{background:#f59e0b1a;border-color:#f59e0b66;color:#fcd34d}.error-text{margin:4px 0;font-size:.82rem;color:#fca5a5}.success-text{padding:12px 16px;border-radius:var(--radius-md);font-size:.82rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#a7f3d0}.info-banner{padding:12px 16px;border-radius:var(--radius-md);font-size:.82rem;background:#3b82f614;border:1px solid rgba(59,130,246,.25);color:#93c5fd}.confirm-bar{display:flex;align-items:center;gap:10px;margin-top:4px;padding:12px 16px;border-radius:var(--radius-md);border:1px solid rgba(245,158,11,.3);background:#f59e0b1a}.skeleton{background:#33415566;border-radius:var(--radius-md);animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-card{height:130px;border-radius:var(--radius-xl)}.skeleton-table-row{height:42px;margin-bottom:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#0009;padding:16px}.modal-card{width:100%;max-width:520px;border-radius:var(--radius-xl);border:1px solid var(--slate-700);background:var(--slate-900);padding:24px;box-shadow:0 24px 64px #00000080;animation:fadeInUp .3s ease-out}.modal-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 16px}.creds-block{padding:16px;border-radius:var(--radius-md);border:1px solid rgba(0,199,127,.25);background:#00c77f0d;display:flex;flex-direction:column;gap:10px}.creds-row{display:flex;justify-content:space-between;align-items:center}.creds-row code{font-family:Courier New,monospace;font-size:.9rem;font-weight:600;color:var(--accent);letter-spacing:.02em}.gen-login-preview{padding:10px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:#0f172a66;display:flex;align-items:center;gap:10px}.gen-login-preview code{font-family:Courier New,monospace;font-size:.9rem;font-weight:600;color:var(--text-primary);letter-spacing:.02em}.page-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.disc-inline{display:flex;gap:4px}.disc-pill{display:inline-flex;align-items:center;justify-content:center;min-width:38px;padding:2px 6px;border-radius:var(--radius-md);font-size:.68rem;font-weight:600;font-family:monospace}.disc-pill-warn{background:#f59e0b14;color:#f59e0b73;border:1px solid rgba(245,158,11,.2)}.disc-pill-warn.disc-pill-active{background:#f59e0b1f;color:#fcd34d;border-color:#f59e0b66}.disc-pill-repr{background:#ef444414;color:#ef444473;border:1px solid rgba(239,68,68,.2)}.disc-pill-repr.disc-pill-active{background:#ef44441f;color:#fca5a5;border-color:#ef444466}.manage-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:0}.manage-tab{padding:8px 16px;border:none;background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s ease}.manage-tab:hover{color:var(--text-primary)}.manage-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.disc-manage-content{display:flex;flex-direction:column;gap:16px}.disc-manage-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:#0f172a66}.disc-manage-label{display:flex;flex-direction:column;gap:2px}.disc-manage-controls{display:flex;align-items:center;gap:12px}.disc-ctrl-btn{width:30px;height:30px;border-radius:var(--radius-md);border:1px solid var(--slate-600);background:transparent;color:var(--text-secondary);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.disc-ctrl-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.disc-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.disc-ctrl-value{font-size:1.1rem;font-weight:700;min-width:24px;text-align:center}.disc-warn-val{color:#fcd34d}.disc-repr-val{color:#fca5a5}.btn-danger-outline{padding:6px 12px;border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.4);background:transparent;color:#fca5a5;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-danger-outline:hover{background:#ef44441a;border-color:#ef444499}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-xl);border:1px solid var(--border);background:#0f172a66;padding:48px 24px;text-align:center}.empty-state-title{font-size:.95rem;font-weight:500;color:var(--text-secondary);margin:0}.empty-state-desc{font-size:.82rem;color:var(--text-faint);margin:8px 0 0;max-width:320px}.wl-table-wrapper{border-radius:var(--radius-xl);border:1px solid var(--border);overflow:hidden}.wl-table{width:100%;border-collapse:collapse;font-size:.82rem}.wl-table thead{border-bottom:1px solid var(--slate-700)}.wl-table th{text-align:left;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:12px 16px}.wl-table td{padding:12px 16px;color:var(--text-secondary)}.wl-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s ease}.wl-table tbody tr:last-child{border-bottom:none}.wl-table tbody tr:hover{background:#00c77f08}.wl-empty{text-align:center;color:var(--text-faint);padding:32px 16px!important}.td-reason{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.login-card{width:100%;max-width:380px;padding:32px;border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-card-solid);animation:fadeInUp .6s ease-out forwards;opacity:0}.login-logo{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px}.login-logo-text{font-size:1.25rem;font-weight:700;color:var(--accent);letter-spacing:.06em;text-transform:uppercase}.login-logo-sub{font-size:.72rem;color:var(--text-faint)}.login-form{display:flex;flex-direction:column;gap:16px}.disc-badge{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;padding:3px 8px;border-radius:var(--radius-md);border:1px solid}.disc-warn{background:#f59e0b1a;border-color:#f59e0b4d;color:#fcd34d}.disc-reprimand{background:#ef44441a;border-color:#ef44444d;color:#fca5a5}.disc-btn{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:.75rem;background:#0f172a99;border:1px solid var(--slate-700);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:border-color .2s ease,color .2s ease}.disc-btn:hover{border-color:var(--accent);color:var(--accent)}.disc-profile-bar{display:flex;gap:12px;margin-bottom:20px;padding:12px 16px;border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-card)}.disc-profile-item{display:flex;align-items:center}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{border-radius:var(--radius-xl);border:1px solid var(--border);background:#1e293b80;padding:16px;display:flex;flex-direction:column;gap:4px;transition:border-color .3s ease}.stat-card:hover{border-color:var(--border-hover)}.stat-label,.stat-card-label{font-size:.82rem;color:var(--text-muted);margin:0}.stat-value,.stat-card-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.period-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.period-btn{padding:6px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s ease}.period-btn:hover{color:var(--text-primary);border-color:var(--border-hover)}.period-btn-active{color:var(--accent);border-color:var(--accent);background:#00c77f0d}.history-feed{display:flex;flex-direction:column;gap:10px}.history-item{padding:12px 16px;border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-card);font-size:.82rem;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center;transition:border-color .3s ease}.history-item:hover{border-color:var(--border-hover)}.history-item-meta{font-size:.72rem;color:var(--text-faint);white-space:nowrap}.stats-table-wrap{border-radius:var(--radius-xl);border:1px solid var(--border);overflow:hidden}.ranking-pos{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;background:#0f172a99;border:1px solid var(--slate-700);color:var(--text-secondary)}.ranking-pos.top-3{background:#00c77f1a;border-color:#00c77f4d;color:var(--accent)}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.role-perm-card{border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-card);padding:16px;transition:border-color .3s ease}.role-perm-card:hover{border-color:var(--border-hover)}.perm-list{display:flex;flex-direction:column;gap:6px}.perm-item{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--text-secondary);cursor:pointer;padding:4px 0}.perm-item:hover{color:var(--text-primary)}.perm-check{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.perm-check:disabled{cursor:default;opacity:.5}details.add-form-details{margin-top:20px;padding-top:14px;border-top:1px solid var(--border)}details.add-form-details summary{display:inline-flex;padding:6px 14px;border-radius:var(--radius-md);border:1px solid var(--slate-600);background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s ease;list-style:none}details.add-form-details summary::-webkit-details-marker{display:none}details.add-form-details summary:hover{border-color:var(--accent);color:var(--accent)}details.add-form-details[open] summary{margin-bottom:12px}.audit-table th,.audit-table td{padding:8px 10px}.audit-action-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-md);font-size:.68rem;font-weight:600;background:#00c77f14;border:1px solid rgba(0,199,127,.2);color:var(--accent);white-space:nowrap}.audit-method{display:inline-block;padding:1px 6px;border-radius:3px;font-size:.65rem;font-weight:700;font-family:monospace;letter-spacing:.03em}.method-get{background:#3b82f61a;color:#93c5fd}.method-post{background:#10b9811a;color:#6ee7b7}.method-patch{background:#f59e0b1a;color:#fcd34d}.method-delete{background:#ef44441a;color:#fca5a5}.audit-status{display:inline-block;padding:1px 6px;border-radius:3px;font-size:.68rem;font-weight:600;font-family:monospace}.status-ok{background:#10b9811a;color:#6ee7b7}.status-warn{background:#f59e0b1a;color:#fcd34d}.status-err{background:#ef44441a;color:#fca5a5}.audit-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
