.roles-matrix-container{background:0 0;border:none;display:flex;flex-direction:column;height:calc(100vh - 270px);min-height:300px;max-height:calc(100vh - 270px)}.roles-matrix-hero{flex-shrink:0;display:flex;align-items:center;gap:var(--pref-section-header-gap);padding-bottom:12px;margin-bottom:12px;background:0 0}.roles-matrix-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.roles-matrix-title{font-size:var(--pref-section-title-size);font-weight:500;color:var(--text-near-white);margin:0 0 4px 0}.roles-matrix-description{font-size:var(--pref-section-desc-size);color:var(--text-muted);margin:0}.roles-matrix-controls{display:flex;align-items:center;gap:10px;flex-shrink:0}.roles-search-wrapper{position:relative;display:flex;align-items:center}.roles-search-wrapper i{position:absolute;left:10px;color:var(--text-dim);font-size:.75rem;pointer-events:none}.roles-search-input{width:180px;height:36px;padding:0 12px 0 32px;background:0 0;border:1px solid var(--border-sharp);border-radius:6px;color:var(--text-bright);font-size:.8rem;font-family:inherit;outline:0;transition:background-color .2s ease,border-color .2s ease}.roles-search-input::placeholder{color:var(--text-dim)}.roles-search-input:focus{background:var(--surface-01);border-color:var(--border-subtle)}.roles-refresh-btn{-webkit-appearance:none;appearance:none;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:0 0;border:1px solid var(--border-sharp);border-radius:6px;color:var(--text-icon);cursor:pointer;transition:background-color .2s ease,color .2s ease,border-color .2s ease,transform .2s ease}.roles-refresh-btn:hover{background:var(--surface-code);color:var(--text-bright);border-color:var(--border-subtle)}.roles-refresh-btn:active{transform:scale(.95)}.roles-matrix-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.roles-table tbody{scrollbar-width:thin;scrollbar-color:var(--border-light) transparent}.roles-table tbody::-webkit-scrollbar{width:6px}.roles-table tbody::-webkit-scrollbar-track{background:0 0}.roles-table tbody::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.roles-table tbody::-webkit-scrollbar-thumb:hover{background:var(--border-heavy)}.roles-table-wrapper .pref-loading{flex:1;min-height:200px}.roles-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-icon);font-size:.85rem;text-align:center}.roles-error i{font-size:1.5rem;opacity:.5}.roles-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-dimmed);font-size:.85rem}.roles-empty i{font-size:1.5rem;opacity:.5}.roles-table-wrapper{flex:1;overflow:hidden;border:1px solid var(--border-light);border-radius:8px;display:flex;flex-direction:column;min-height:0}.roles-table{width:100%;border-collapse:collapse;font-size:.85rem;display:flex;flex-direction:column;height:100%}.roles-table thead{flex-shrink:0}.roles-table tbody{flex:1;overflow-y:auto}.roles-table tbody tr,.roles-table thead tr{display:table;width:100%;table-layout:fixed}.roles-table th{padding:12px 16px;text-align:left;font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-icon);background:var(--page-bg-alt);border-bottom:1px solid var(--surface-hover);white-space:nowrap}.roles-table td.roles-user-cell,.roles-table th.roles-user-col{width:250px}.roles-table td.roles-checkbox-cell,.roles-table th.roles-role-col{text-align:center;width:100px}.roles-table td{padding:12px 16px;border-bottom:1px solid var(--surface-02)}.roles-user-row{height:52px;transition:background .15s ease}.roles-user-row:hover{background:var(--surface-01)}.roles-user-row:last-child td{border-bottom:none}.roles-empty-row{pointer-events:none}.roles-empty-row td{border-bottom-color:transparent}.roles-user-cell{min-width:200px}.roles-user-info{display:flex;flex-direction:column;gap:2px}.roles-user-info.clickable{cursor:pointer}.roles-user-info.clickable:hover .roles-user-email{color:var(--text-bright)}.roles-user-email{color:var(--text-emphasis);font-weight:400;transition:color .15s ease}.roles-user-meta{font-size:.7rem;color:var(--text-dimmed)}.roles-checkbox-cell{text-align:center}.roles-checkbox-wrapper{display:inline-flex;align-items:center;justify-content:center;position:relative;cursor:pointer;padding:4px}.roles-checkbox-wrapper.pending{opacity:.5;pointer-events:none}.roles-checkbox{position:absolute;opacity:0;width:0;height:0}.roles-checkbox-mark{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:0 0;border:1.5px solid var(--border-medium);border-radius:4px;transition:background-color .2s ease,border-color .2s ease,opacity .2s ease}.roles-checkbox-mark::after{content:'';display:none;width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}.roles-checkbox:checked+.roles-checkbox-mark{background:var(--accent-green-border);border-color:rgba(74,222,128,.4)}.roles-checkbox:checked+.roles-checkbox-mark::after{display:block}.roles-checkbox-wrapper:hover .roles-checkbox-mark{border-color:var(--border-xheavy);background:var(--surface-01)}.roles-checkbox:checked:hover+.roles-checkbox-mark{background:rgba(74,222,128,.25);border-color:rgba(74,222,128,.5)}.roles-checkbox:disabled+.roles-checkbox-mark{opacity:.5;cursor:default}.roles-footer{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:12px 0;margin-top:auto}.roles-user-count{font-size:.75rem;color:var(--text-icon)}.roles-pagination{display:flex;align-items:center;gap:8px}.roles-page-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:0 0;border:1px solid var(--border-sharp);border-radius:5px;color:var(--text-label);font-size:.7rem;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease,transform .15s ease,opacity .15s ease}.roles-page-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text-near-white);border-color:var(--border-medium)}.roles-page-btn:active:not(:disabled){transform:scale(.95)}.roles-page-btn:disabled{opacity:.3;cursor:default}.roles-page-info{font-size:.75rem;color:var(--text-soft);min-width:50px;text-align:center}.roles-toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--surface-toast);border:1px solid var(--border-light);border-radius:8px;color:var(--text-bright);font-size:.85rem;box-shadow:var(--shadow-xl);z-index:10000;opacity:0;transform:translateY(10px);transition:opacity .3s ease,transform .3s ease}.roles-toast.visible{opacity:1;transform:none}.roles-toast-success i{color:var(--accent-green)}.roles-toast-error i{color:var(--text-secondary-alt)}.adm-root{max-width:1100px;margin:0 auto;padding:0 0 64px}.adm-header{display:flex;align-items:center;justify-content:space-between;padding:24px 0 16px;border-bottom:1px solid var(--border-faint);margin-bottom:16px;gap:16px}.adm-header-left{display:flex;align-items:center;gap:14px}.adm-header-icon{width:38px;height:38px;border-radius:8px;background:0 0;border:1px solid var(--border-faint);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-icon);flex-shrink:0;transition:background-color .2s ease,border-color .2s ease,color .2s ease,opacity .2s ease,box-shadow .2s ease,transform .2s ease}.adm-header-title{font-size:15px;font-weight:500;color:var(--text-near-white);margin-bottom:2px}.adm-header-sub{font-size:12px;color:var(--text-muted)}.adm-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border-faint);padding-bottom:0}.adm-tab{-webkit-appearance:none;appearance:none;background:0 0;border:none;border-bottom:2px solid transparent;padding:8px 16px;font-size:13px;font-weight:500;font-family:inherit;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:6px;margin-bottom:-1px;transition:color .15s ease,border-color .15s ease;outline:0}.adm-tab:hover{color:var(--text-bright)}.adm-tab.active{color:var(--text-bright);border-bottom-color:var(--accent-blue-solid)}.adm-loading{display:flex;align-items:center;gap:12px;padding:48px 20px;color:var(--text-muted);font-size:13px}.adm-stats-bar{display:flex;align-items:center;gap:24px;padding:12px 16px;background:var(--page-bg-alt);border:1px solid var(--border-faint);border-radius:8px;margin-bottom:16px;flex-wrap:wrap}.adm-stat{display:flex;flex-direction:column;gap:3px}.adm-stat-val{font-size:18px;font-weight:600;color:var(--text-near-white);line-height:1;font-variant-numeric:tabular-nums}.adm-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-icon);font-weight:600}.adm-stat-plans{flex-direction:row;align-items:center;gap:6px;flex-wrap:wrap}.adm-stat-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border-faint);background:var(--surface-hover);color:var(--text-icon)}.adm-stat-chip[data-plan=starter]{background:var(--accent-blue-bg);border-color:var(--accent-blue-border);color:var(--accent-blue-muted)}.adm-stat-chip[data-plan=pro]{background:var(--accent-green-bg);border-color:var(--accent-green-border);color:var(--accent-green)}.adm-stat-chip[data-plan=max]{background:var(--accent-orange-bg);border-color:var(--accent-orange-border);color:var(--accent-orange)}.adm-stat-chip[data-plan=enterprise]{background:var(--accent-orange-bg);border-color:var(--accent-orange-border);color:var(--accent-orange)}.adm-chip-count{opacity:.75}.adm-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.adm-search-wrap{position:relative;display:flex;align-items:center;flex:1;min-width:180px}.adm-search-wrap i{position:absolute;left:10px;color:var(--text-icon);font-size:11px;pointer-events:none}.adm-search-input{width:100%;height:36px;padding:0 12px 0 30px;background:var(--surface-01);border:1px solid var(--border-faint);border-radius:6px;color:var(--text-bright);font-size:.85rem;font-family:inherit;outline:0;transition:background-color .2s ease,border-color .2s ease}.adm-search-input::placeholder{color:var(--text-dimmed)}.adm-search-input:focus{background:var(--surface-code);border-color:var(--border-sharp)}.adm-plan-filter{-webkit-appearance:none;appearance:none;height:36px;padding:0 10px;background:var(--surface-01);border:1px solid var(--border-faint);border-radius:6px;color:var(--text-bright);font-size:.85rem;font-family:inherit;outline:0;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.adm-plan-filter:focus{background:var(--surface-code);border-color:var(--border-sharp)}.adm-refresh-btn{-webkit-appearance:none;appearance:none;height:36px;width:36px;background:var(--surface-hover);border:1px solid var(--border-light);border-radius:6px;color:var(--text-high);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;transition:background-color .15s ease,color .15s ease,border-color .15s ease;outline:0;flex-shrink:0}.adm-refresh-btn:hover{background:var(--border-light);color:var(--text-bright);border-color:var(--border-medium)}.adm-table-wrap{overflow-x:auto;border:1px solid var(--border-faint);border-radius:8px;margin-bottom:12px}.adm-table{width:100%;border-collapse:collapse;font-size:.8rem}.adm-table thead{background:var(--page-bg-alt)}.adm-table th{padding:9px 14px;text-align:left;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-icon);border-bottom:1px solid var(--border-faint);white-space:nowrap}.adm-table td{padding:10px 14px;border-bottom:1px solid var(--surface-02);vertical-align:middle;color:var(--text-muted)}.adm-table tbody tr:last-child td{border-bottom:none}.adm-user-row:hover{background:var(--surface-01)}.adm-user-cell{max-width:220px}.adm-user-email{display:block;font-size:.8rem;color:var(--text-emphasis);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.adm-user-email.clickable{cursor:pointer}.adm-user-email.clickable:hover{color:var(--accent-blue-muted)}.adm-user-joined{display:block;font-size:.7rem;color:var(--text-dimmed);margin-top:2px}.adm-plan-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--surface-hover);color:var(--text-icon);border:1px solid var(--border-faint);white-space:nowrap}.adm-plan-badge[data-plan=starter]{background:var(--accent-blue-bg);border-color:var(--accent-blue-border);color:var(--accent-blue-muted)}.adm-plan-badge[data-plan=pro]{background:var(--accent-green-bg);border-color:var(--accent-green-border);color:var(--accent-green)}.adm-plan-badge[data-plan=max]{background:var(--accent-orange-bg);border-color:var(--accent-orange-border);color:var(--accent-orange)}.adm-plan-badge[data-plan=enterprise]{background:var(--accent-orange-bg);border-color:var(--accent-orange-border);color:var(--accent-orange)}.adm-sub-cell{white-space:nowrap}.adm-sub-badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:capitalize;letter-spacing:.04em;border:1px solid}.adm-sub-badge.active{background:var(--accent-green-bg);color:var(--accent-green);border-color:var(--accent-green-border)}.adm-sub-badge.trial{background:var(--accent-blue-bg);color:var(--accent-blue-muted);border-color:var(--accent-blue-border)}.adm-sub-badge.cancelled{background:var(--accent-red-bg);color:var(--accent-red);border-color:var(--accent-red-border)}.adm-sub-badge.muted{background:var(--surface-hover);color:var(--text-icon);border-color:var(--border-faint)}.adm-renew-date{font-size:.7rem;color:var(--text-dimmed);margin-left:5px}.adm-pm{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--text-muted)}.adm-pm i{color:var(--text-icon)}.adm-pm-none{color:var(--text-dimmed);font-size:.8rem}.adm-mrr{font-weight:600;font-size:.8rem;color:var(--text-high);font-variant-numeric:tabular-nums}.adm-mrr-zero{color:var(--text-dimmed);font-size:.8rem}.adm-actions-cell{white-space:nowrap}.adm-action-btn{-webkit-appearance:none;appearance:none;background:0 0;border:1px solid transparent;border-radius:5px;padding:4px 8px;font-size:11px;cursor:pointer;color:var(--text-icon);margin-right:2px;transition:background-color .12s ease,color .12s ease,border-color .12s ease;outline:0}.adm-action-btn:hover{background:var(--surface-hover);color:var(--text-bright);border-color:var(--border-sharp)}.adm-pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 2px;font-size:.75rem;color:var(--text-muted)}.adm-page-btns{display:flex;align-items:center;gap:6px}.adm-page-btn{-webkit-appearance:none;appearance:none;background:0 0;border:1px solid var(--border-sharp);border-radius:5px;padding:4px 9px;font-size:11px;cursor:pointer;color:var(--text-label);font-family:inherit;transition:opacity .12s ease,background-color .12s ease,color .12s ease,border-color .12s ease;outline:0}.adm-page-btn:disabled{opacity:.3;cursor:default}.adm-page-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text-bright);border-color:var(--border-medium)}.adm-total-count{font-size:.75rem;color:var(--text-muted)}.adm-empty{display:flex;align-items:center;gap:12px;padding:48px 20px;color:var(--text-muted);font-size:.82rem}.adm-empty i{font-size:18px;opacity:.5}.adm-invoices-table .adm-inv-email.clickable{cursor:pointer}.adm-invoices-table .adm-inv-email.clickable:hover{color:var(--accent-blue-muted)}.adm-inv-amount{font-weight:500;font-variant-numeric:tabular-nums;color:var(--text-high)}.adm-inv-amount.credit{color:var(--accent-green)}.adm-invoice-status{display:inline-block;padding:2px 8px;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:1px solid}.adm-invoice-status.paid{background:var(--accent-green-bg);color:var(--accent-green);border-color:var(--accent-green-border)}.adm-invoice-status.failed{background:var(--accent-red-bg);color:var(--accent-red);border-color:var(--accent-red-border)}.adm-invoice-status.refunded{background:var(--accent-orange-bg);color:var(--accent-orange);border-color:var(--accent-orange-border)}.adm-invoice-status.pending{background:var(--surface-hover);color:var(--text-icon);border-color:var(--border-faint)}.adm-inv-issued{font-size:.7rem;color:var(--text-dimmed)}.adm-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}.adm-modal{background:var(--page-bg-alt);border:1px solid var(--border-light);border-radius:12px;width:100%;max-width:440px;box-shadow:0 24px 80px rgba(0,0,0,.5);overflow:hidden}.adm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--surface-hover)}.adm-modal-header h4{margin:0;font-size:.9rem;font-weight:500;color:var(--text-bright)}.adm-modal-close{-webkit-appearance:none;appearance:none;background:0 0;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-muted);padding:2px 6px;border-radius:4px;line-height:1;outline:0;transition:background-color .15s ease,color .15s ease}.adm-modal-close:hover{background:var(--surface-hover);color:var(--text-bright)}.adm-modal-body{padding:14px 18px}.adm-modal-sub{font-size:.82rem;color:var(--text-muted);margin:0 0 14px;line-height:1.5}.adm-modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:12px 18px;border-top:1px solid var(--surface-hover)}.adm-form-group{margin-bottom:14px}.adm-form-group label{display:block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-icon);margin-bottom:6px}.adm-form-group input[type=number],.adm-form-group input[type=text],.adm-form-group select{-webkit-appearance:none;appearance:none;width:100%;height:34px;padding:0 12px;background:var(--surface-01);border:1px solid var(--border-sharp);border-radius:6px;color:var(--text-bright);font-size:.82rem;font-family:inherit;outline:0;box-sizing:border-box;transition:border-color .15s ease}.adm-form-group input:focus,.adm-form-group select:focus{border-color:var(--accent-blue-focus)}.adm-required{color:var(--accent-red)}.adm-modal-note{font-size:.75rem;color:var(--text-muted);display:flex;align-items:flex-start;gap:6px;padding:8px 10px;background:var(--surface-01);border-radius:6px;margin:12px 0 0;line-height:1.5}.adm-modal-note i{margin-top:1px;flex-shrink:0;color:var(--text-icon)}.adm-note-warn{background:var(--accent-red-bg)}.adm-note-warn i{color:var(--accent-red)}.adm-btn{-webkit-appearance:none;appearance:none;border:1px solid transparent;border-radius:6px;padding:0 14px;height:32px;font-size:.8rem;font-weight:500;font-family:inherit;cursor:pointer;transition:opacity .12s ease,filter .12s ease,background-color .12s ease,color .12s ease,border-color .12s ease;outline:0}.adm-btn:disabled{opacity:.4;cursor:default}.adm-btn-primary{background:var(--accent-blue-solid);color:#fff;border-color:transparent}.adm-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.adm-btn-ghost{background:0 0;color:var(--text-label);border-color:var(--border-light)}.adm-btn-ghost:hover:not(:disabled){background:var(--surface-code);color:var(--text-bright);border-color:var(--border-medium)}.adm-btn-danger{background:var(--accent-red-bg);color:var(--accent-red);border-color:var(--accent-red-border)}.adm-btn-danger:hover:not(:disabled){background:var(--accent-red-solid);color:#fff;border-color:transparent}@media (max-width:768px){.adm-table-wrap{font-size:12px}.adm-stats-bar{gap:16px;padding:10px 14px}}@media (max-width:768px){.roles-matrix-container{height:calc(100vh - 180px);min-height:280px;max-height:calc(100vh - 180px)}.roles-matrix-hero{flex-direction:column;text-align:center;gap:16px;padding-bottom:16px;margin-bottom:16px}.roles-matrix-icon{width:64px;height:64px}.roles-matrix-icon i{font-size:1.5rem}.roles-matrix-controls{width:100%;justify-content:center}.roles-search-input{width:100%;flex:1}.roles-table td,.roles-table th{padding:10px 12px}.roles-user-cell{min-width:150px}.roles-table th.roles-role-col{min-width:80px}.roles-toast{left:16px;right:16px;bottom:16px}}