*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0f;--bg2:#111118;--surface:#16161f;--surface2:#1c1c28;--border:#2a2a3a;--border2:#222230;--text:#f0f0f5;--muted:#7c7c9a;--muted2:#4e4e6a;--accent:#f0f0f5;--accent-fg:#0a0a0f;--green:#22c55e;--green-dim:rgba(34,197,94,0.12);--green-border:rgba(34,197,94,0.25);--red:#f87171;--red-dim:rgba(248,113,113,0.1);--red-border:rgba(248,113,113,0.2);--blue:#60a5fa;--blue-dim:rgba(96,165,250,0.12);--blue-border:rgba(96,165,250,0.25);--purple:#a78bfa;--purple-dim:rgba(167,139,250,0.12);--yellow:#fbbf24;--radius:10px;--sh:0 1px 2px rgba(0,0,0,0.4);--sh-md:0 2px 8px rgba(0,0,0,0.5),0 1px 2px rgba(0,0,0,0.3)}body,html{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased;min-height:100svh}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.app-shell{display:flex;min-height:100svh}.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:30}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;border-bottom:1px solid var(--border)}.sidebar-brand-name{font-size:16px;font-weight:700;letter-spacing:-.02em}.sidebar-brand-sub{font-size:10px;color:var(--muted2);letter-spacing:.04em;text-transform:uppercase}.sidebar-nav{flex:1 1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-section{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);padding:8px 8px 4px;margin-top:8px}.sidebar-section:first-child{margin-top:0}.nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .1s,color .1s;text-decoration:none}.nav-item.active,.nav-item:hover{background:var(--surface2);color:var(--text)}.sidebar-bottom{padding:12px 8px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .1s}.sidebar-user:hover{background:var(--surface2)}.sidebar-user-info{flex:1 1;min-width:0}.sidebar-user-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:10px;color:var(--muted2)}.main{margin-left:220px;flex:1 1;min-width:0;display:flex;flex-direction:column}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;height:54px;padding:0 24px;display:flex;align-items:center;gap:12px;background:rgba(10,10,15,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.topbar-title{font-size:15px;font-weight:600;letter-spacing:-.01em;flex:1 1}.page-content{padding:24px;max-width:1100px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--sh-md)}.card-header{padding:16px 20px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:10px}.card-title{font-size:14px;font-weight:600}.card-body{padding:16px 20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:12px;gap:12px;margin-bottom:24px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--sh)}.stat-label{font-size:11px;color:var(--muted);margin-bottom:6px}.stat-value{font-size:24px;font-weight:700;letter-spacing:-.03em}.stat-sub{font-size:11px;color:var(--muted2);margin-top:2px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted2);border-bottom:1px solid var(--border)}td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--border2);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface2)}.td-muted{color:var(--muted);font-size:12px}.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:600;letter-spacing:.03em}.badge.green{background:var(--green-dim);color:var(--green);border:1px solid var(--green-border)}.badge.red{background:var(--red-dim);color:var(--red);border:1px solid var(--red-border)}.badge.blue{background:var(--blue-dim);color:var(--blue);border:1px solid var(--blue-border)}.badge.purple{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(167,139,250,.25)}.badge.muted{background:var(--surface2);color:var(--muted);border:1px solid var(--border)}.badge.yellow{background:rgba(251,191,36,.12);color:var(--yellow);border:1px solid rgba(251,191,36,.25)}.avatar{display:flex;justify-content:center;font-weight:600;color:white;flex-shrink:0;letter-spacing:-.01em}.avatar,.btn{align-items:center;border-radius:8px}.btn{display:inline-flex;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,background .1s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-fg)}.btn-primary:hover:not(:disabled){opacity:.9}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border2)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid var(--red-border)}.btn-danger:hover:not(:disabled){background:rgba(248,113,113,.18)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface2);color:var(--text)}.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}.btn-icon{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:7px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-bottom:5px}.field input,.field select,.field textarea{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:9px 11px;font-family:inherit;font-size:14px;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--muted);box-shadow:0 0 0 3px rgba(240,240,245,.06)}.field select{cursor:pointer}.field textarea{min-height:80px;resize:vertical}.field-hint{font-size:11px;color:var(--muted2);margin-top:4px}.field-row{display:flex;gap:12px}.field-row .field{flex:1 1}.sl{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted2);margin-bottom:10px}.overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fi .15s ease}@keyframes fi{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh-md);animation:pop .2s cubic-bezier(.32,.72,0,1);max-height:90vh;overflow-y:auto}@keyframes pop{0%{opacity:0;transform:scale(.96) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:600;letter-spacing:-.01em}.modal-body{padding:16px 24px}.modal-footer{padding:0 24px 20px;display:flex;justify-content:flex-end;gap:8px}.modal-lg{max-width:640px}.perm-group{margin-bottom:16px}.perm-group-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted2);margin-bottom:8px}.perm-list{display:flex;flex-direction:column;gap:4px}.perm-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:7px;cursor:pointer;transition:background .1s;border:1px solid transparent}.perm-item:hover{background:var(--surface2)}.perm-item.checked{background:var(--blue-dim);border-color:var(--blue-border)}.perm-item.checked .perm-key{color:var(--blue)}.perm-checkbox{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}.perm-item.checked .perm-checkbox{background:var(--blue);border-color:var(--blue)}.perm-key{font-size:12px;font-family:monospace;color:var(--muted);flex:1 1}.login-wrap{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:36px 28px;box-shadow:var(--sh-md)}.login-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:28px}.login-title{font-size:22px;font-weight:700;letter-spacing:-.03em;margin-top:12px}.login-sub{font-size:13px;color:var(--muted);margin-top:4px}.login-btn{width:100%;padding:11px;background:var(--accent);color:var(--accent-fg);border:none;border-radius:9px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}.login-btn:hover:not(:disabled){opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.alert{padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:12px}.alert-error{background:var(--red-dim);border:1px solid var(--red-border);color:var(--red)}.alert-success{background:var(--green-dim);border:1px solid var(--green-border);color:var(--green)}.alert-info{background:var(--blue-dim);border:1px solid var(--blue-border);color:var(--blue)}.toast{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:300;padding:10px 16px;border-radius:10px;font-size:13px;cursor:pointer;white-space:nowrap;max-width:calc(100vw - 32px);box-shadow:var(--sh-md);animation:fi .2s ease}.toast.error{background:var(--red-dim);border:1px solid var(--red-border);color:var(--red)}.toast.success{background:var(--green-dim);border:1px solid var(--green-border);color:var(--green)}.spinner{display:inline-block;border-radius:50%;border:2px solid rgba(10,10,15,.2);border-top:2px solid var(--accent-fg);animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.tag-list{display:flex;flex-wrap:wrap;gap:4px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:11px;font-family:monospace;background:var(--surface2);border:1px solid var(--border2)}.empty,.tag{color:var(--muted)}.empty{text-align:center;padding:48px 20px}.empty-title{font-size:15px;font-weight:600;color:var(--text);margin:10px 0 4px}.empty-sub{font-size:13px;color:var(--muted2)}.divider{height:1px;background:var(--border2);margin:16px 0}.confirm-dialog{background:var(--surface);border-radius:14px;padding:28px 24px 20px;max-width:360px;width:100%;text-align:center;flex-direction:column;gap:8px;animation:pop .2s cubic-bezier(.32,.72,0,1)}.confirm-dialog,.confirm-icon{display:flex;align-items:center}.confirm-icon{width:48px;height:48px;border-radius:50%;background:var(--red-dim);color:var(--red);justify-content:center;margin-bottom:4px}.confirm-title{font-size:16px;font-weight:700}.confirm-msg{font-size:13px;color:var(--muted);line-height:1.5}.confirm-actions{display:flex;gap:8px;width:100%;margin-top:8px}.confirm-actions button{flex:1 1;padding:10px;border-radius:9px;font-family:inherit;font-size:13px;font-weight:600;border:none;cursor:pointer}.btn-cancel{background:var(--surface2)!important;color:var(--text)!important;border:1px solid var(--border)!important}.btn-confirm{background:var(--red)!important;color:white!important}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab-btn{padding:8px 14px;background:none;font-family:inherit;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border:none;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab-btn.active,.tab-btn:hover{color:var(--text)}.tab-btn.active{border-bottom-color:var(--text)}.row-actions{display:flex;gap:6px}.icon-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;transition:background .1s,color .1s}.icon-btn:hover{background:var(--surface2);color:var(--text)}.icon-btn.danger:hover{color:var(--red);border-color:var(--red-border);background:var(--red-dim)}.search-wrap{position:relative}.search-wrap input{padding-left:34px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted2);pointer-events:none}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .25s ease}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.page,.page-content{padding:16px}.topbar{padding:0 14px;height:48px}.topbar-title{font-size:14px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.dashboard-grid{grid-template-columns:1fr}.field-row{flex-direction:column;gap:0}.modal{border-radius:12px;margin:8px}.modal-header{padding:16px 18px 0}.modal-body{padding:12px 18px}.modal-footer{padding:0 18px 16px}.card-header{flex-wrap:wrap;gap:8px}.card-body,.card-header{padding:12px 14px}th{padding:8px 10px;font-size:10px}td{padding:10px}.btn,td{font-size:12px}.btn{padding:7px 10px}.btn-sm{padding:4px 8px;font-size:11px}.confirm-dialog{padding:24px 18px 16px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-btn{padding:8px 10px;font-size:12px;white-space:nowrap}.perm-item{padding:6px 8px}.perm-key{font-size:11px}.toast{font-size:12px;padding:8px 12px}.tag-list{gap:3px}.tag{font-size:10px;padding:1px 6px}.row-actions{gap:4px}.icon-btn{width:26px;height:26px}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.stat-value{font-size:20px}.confirm-actions{flex-direction:column}.confirm-actions button{width:100%}}.layout{display:flex;min-height:100svh}.page{padding:24px;max-width:1100px}.topbar-sub{font-size:11px;color:var(--muted2);margin-top:1px}.mobile-nav-btn{display:none;width:32px;height:32px;border:1px solid var(--border);background:var(--surface);border-radius:7px;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);flex-shrink:0}@media (max-width:768px){.mobile-nav-btn{display:flex}}.sidebar-title{font-size:15px;font-weight:700;letter-spacing:-.02em}.nav-section{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);padding:8px 8px 4px;margin-top:8px}.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border)}.user-chip{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .1s}.user-chip:hover{background:var(--surface2)}.user-chip-info{flex:1 1;min-width:0}.user-chip-name{font-size:12px;font-weight:500}.user-chip-email,.user-chip-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chip-email{font-size:10px;color:var(--muted2)}