:root{--ink: #0e1525;--bg: #f5f6f8;--surface: #ffffff;--border: #e4e7ec;--text: #0e1525;--text-muted: #667085;--gradient: linear-gradient(90deg, #3730d8 0%, #8b3fd6 50%, #e5396b 100%);--font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.wordmark{font-weight:700;font-size:1.5rem;letter-spacing:-.02em;background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:transparent}.wordmark-light{font-size:1.4rem}.login-page{min-height:100vh;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:14px;padding:40px 32px;box-shadow:0 8px 30px #0e15250f;display:flex;flex-direction:column;gap:18px}.login-subtitle{margin:0 0 8px;color:var(--text-muted);font-size:.95rem}.field{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:500;color:var(--text-muted)}.field input{font:inherit;color:var(--text);padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff}.field input:focus{outline:none;border-color:#8b3fd6;box-shadow:0 0 0 3px #8b3fd61f}.field-hint{font-weight:400;font-size:.78rem;color:var(--text-muted)}.form-error{color:#b42318;background:#fef3f2;border:1px solid #fecdca;border-radius:8px;padding:10px 12px;font-size:.85rem}.btn-primary{font:inherit;font-weight:600;color:#fff;border:none;border-radius:8px;padding:11px 16px;cursor:pointer;background:var(--gradient)}.btn-primary:disabled{opacity:.65;cursor:default}.shell{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--ink);color:#fff;display:flex;flex-direction:column;padding:24px 16px}.sidebar-brand{padding:8px 8px 24px}.nav{display:flex;flex-direction:column;gap:4px;flex:1}.nav-item{display:block;padding:10px 14px;border-radius:8px;color:#aeb4c2;text-decoration:none;font-size:.95rem;font-weight:500;border-left:3px solid transparent}.nav-item:hover{color:#fff;background:#ffffff0a}.nav-item.active{color:#fff;background:#ffffff0f;border-image:var(--gradient) 1;border-left:3px solid}.sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding-top:16px;display:flex;flex-direction:column;gap:10px}.user-name{font-size:.9rem;font-weight:500}.btn-logout{font:inherit;font-size:.85rem;color:#aeb4c2;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:8px 12px;cursor:pointer;text-align:left}.btn-logout:hover{color:#fff;border-color:#ffffff4d}.content{flex:1;padding:48px 56px}.page-title{margin:0 0 8px;font-size:1.6rem;font-weight:600}.page-note{margin:0;color:var(--text-muted)}.boot{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.toolbar .page-title{margin:0}.search-input{font:inherit;width:100%;max-width:360px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff;margin-bottom:20px}.search-input:focus{outline:none;border-color:#8b3fd6;box-shadow:0 0 0 3px #8b3fd61f}.table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;font-size:.92rem}.table th{text-align:left;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:12px 16px;background:#fafbfc;border-bottom:1px solid var(--border)}.table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#fafbfc}.cell-muted{color:var(--text-muted)}.cell-actions{display:flex;gap:14px;justify-content:flex-end}.cell-user{display:flex;align-items:center;gap:10px;font-weight:500}.avatar{width:30px;height:30px;border-radius:50%;background:var(--ink);color:#fff;font-size:.72rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{font-size:.78rem;font-weight:500;color:var(--text);background:#f2f3f5;border:1px solid var(--border);border-radius:999px;padding:2px 10px}.badge{font-size:.76rem;font-weight:600;border-radius:999px;padding:3px 10px;text-transform:capitalize}.badge-active{color:#067647;background:#ecfdf3}.badge-invited{color:#175cd3;background:#eff8ff}.badge-suspended{color:#b42318;background:#fef3f2}.badge-disabled,.badge-inactive{color:#475467;background:#f2f4f7}.link-action{font:inherit;font-size:.88rem;font-weight:500;color:#6a37d0;background:none;border:none;cursor:pointer;padding:0}.link-action:hover{text-decoration:underline}.btn-secondary{font:inherit;font-weight:500;color:var(--text);background:#fff;border:1px solid var(--border);border-radius:8px;padding:10px 16px;cursor:pointer}.btn-secondary:hover{background:#fafbfc}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e152566;display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal-card{width:100%;max-width:440px;max-height:90vh;overflow-y:auto;background:var(--surface);border-radius:14px;box-shadow:0 20px 50px #0e152533}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:1.1rem;font-weight:600}.modal-close{font-size:1.4rem;line-height:1;color:var(--text-muted);background:none;border:none;cursor:pointer}.modal-body{padding:24px}.form{display:flex;flex-direction:column;gap:16px}.form-row{display:flex;gap:12px}.form-row .field{flex:1}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.checkbox-list{display:flex;flex-direction:column;gap:8px;border:1px solid var(--border);border-radius:8px;padding:12px}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:400;color:var(--text);cursor:pointer}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.role-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:8px}.role-card-head{display:flex;align-items:center;gap:8px}.role-name{font-weight:600;font-size:1rem}.tag{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:#f2f4f7;border:1px solid var(--border);border-radius:6px;padding:1px 7px}.role-desc{margin:0;color:var(--text-muted);font-size:.9rem;flex:1}.role-count{font-size:.8rem;font-weight:500;color:var(--text-muted)}.matrix-wrap{margin-top:20px;max-height:calc(100vh - 230px);overflow:auto;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.matrix{border-collapse:collapse;width:100%;font-size:.9rem}.matrix th,.matrix td{border-bottom:1px solid var(--border)}.matrix thead th{background:#fafbfc;padding:12px 16px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);position:sticky;top:0;z-index:2;box-shadow:inset 0 -1px 0 var(--border)}.matrix-corner{text-align:left;position:sticky;left:0;z-index:3}.matrix-role{text-align:center;white-space:nowrap}.matrix-saving{display:block;font-size:.65rem;font-weight:500;text-transform:none;letter-spacing:0;color:#8b3fd6}.matrix-module{background:#f2f3f5;font-weight:600;font-size:.85rem;color:var(--text);padding:8px 16px;position:sticky;left:0;z-index:1}.matrix-perm{padding:10px 16px;display:flex;flex-direction:column;position:sticky;left:0;z-index:1;background:var(--surface);box-shadow:inset -1px 0 0 var(--border)}.perm-name{font-weight:500}.perm-code{font-size:.76rem;color:var(--text-muted)}.matrix-cell{text-align:center;padding:10px 16px}.matrix tbody tr:hover td{background:#f7f8fa}.toggle{width:22px;height:22px;border-radius:6px;border:2px solid #475467;background:#fff;cursor:pointer;vertical-align:middle;padding:0;position:relative}.toggle:hover{border-color:var(--ink)}.toggle.on{border-color:transparent;background:var(--gradient)}.toggle.on:after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.toggle:disabled{opacity:.55;cursor:default}
