.page{padding:32px}.page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.page__title{font-size:28px;font-weight:700;color:#202124;margin-bottom:4px}.page__subtitle{font-size:12px;color:#80868b}.tabs{display:flex;border-bottom:2px solid #E8EAED;margin-bottom:32px}.tab{background:none;border:none;padding:8px 24px;font-size:14px;font-weight:500;color:#80868b;cursor:pointer;position:relative;transition:color .15s ease}.tab:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:transparent;transition:background .15s ease}.tab:hover{color:#202124}.tab--active{color:#202124;font-weight:700}.tab-content{min-height:300px}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.toolbar__count{font-size:14px;font-weight:500;color:#3c4043}.toolbar__actions{display:flex;align-items:center;gap:8px}.filter-panel{background:var(--color-card-bg, #FFFFFF);border:1px solid #E8EAED;border-radius:var(--border-radius-md, 8px);padding:16px;margin-bottom:16px}.filter-panel__fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:16px}.filter-panel__actions{display:flex;justify-content:flex-end;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:8px 16px;border-radius:var(--border-radius-md, 8px);font-size:14px;font-weight:500;font-family:var(--font-family-base, "Google Sans", "Roboto", Arial, sans-serif);cursor:pointer;border:1px solid transparent;transition:opacity .15s ease,background .15s ease;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary, #1A73E8);color:#fff;border-color:var(--color-primary, #1A73E8)}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark, #1558B0);border-color:var(--color-primary-dark, #1558B0)}.btn--danger{background:var(--color-danger, #EA4335);color:#fff;border-color:var(--color-danger, #EA4335)}.btn--danger:hover:not(:disabled){opacity:.85}.btn--success{background:var(--color-success, #34A853);color:#fff;border-color:var(--color-success, #34A853)}.btn--success:hover:not(:disabled){background:var(--color-accent-dark, #1E7E34)}.btn--ghost{background:transparent;color:#3c4043;border-color:#dadce0}.btn--ghost:hover:not(:disabled){background:#f8f9fa}.btn--sm{padding:4px 8px;font-size:12px}.btn--full{width:100%}.input{width:100%;padding:8px 16px;border:1px solid #DADCE0;border-radius:var(--border-radius-md, 8px);font-size:14px;color:#202124;background:var(--color-card-bg, #FFFFFF);transition:border-color .15s ease;font-family:var(--font-family-base, "Google Sans", "Roboto", Arial, sans-serif);box-sizing:border-box}.input:focus{outline:none;border-color:var(--color-primary, #1A73E8);box-shadow:0 0 0 3px #1a73e81f}.input--search{max-width:320px}select{width:100%;padding:8px 16px;border:1px solid #DADCE0;border-radius:var(--border-radius-md, 8px);font-size:14px;color:#202124;background:var(--color-card-bg, #FFFFFF);transition:border-color .15s ease;font-family:var(--font-family-base, "Google Sans", "Roboto", Arial, sans-serif);box-sizing:border-box;cursor:pointer;appearance:auto}select:focus{outline:none;border-color:var(--color-primary, #1A73E8);box-shadow:0 0 0 3px #1a73e81f}.form-field{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.form-field label{font-size:12px;font-weight:500;color:#5f6368}.form-field input,.form-field select,.form-field textarea{padding:8px 16px;border:1px solid #DADCE0;border-radius:var(--border-radius-md, 8px);font-size:14px;color:#202124;background:var(--color-card-bg, #FFFFFF);font-family:var(--font-family-base, "Google Sans", "Roboto", Arial, sans-serif);transition:border-color .15s ease}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--color-primary, #1A73E8);box-shadow:0 0 0 3px #1a73e81f}.form-field__error{font-size:12px;color:var(--color-danger, #EA4335)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.table-wrap{background:var(--color-card-bg, #FFFFFF);border-radius:var(--border-radius-lg, 12px);box-shadow:0 1px 2px #00000014;overflow-x:auto;margin-bottom:24px;border:1px solid #E8EAED}.table-loading{padding:32px;text-align:center;color:#80868b;font-size:14px}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{padding:8px 16px;text-align:left;font-size:12px;font-weight:500;color:#80868b;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #E8EAED;background:#f8f9fa}.table td{padding:8px 16px;border-bottom:1px solid #E8EAED;color:#3c4043;vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#f8f9fa}.table__empty{text-align:center;color:#80868b;padding:32px!important;font-size:14px}.actions{display:flex;gap:4px;flex-wrap:wrap}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:500;line-height:1.4}.badge--active{background:#e6f4ea;color:#1e7e34}.badge--inactive{background:#fce8e6;color:#c5221f}.badge--success{background:#e6f4ea;color:#1e7e34}.badge--warn{background:#fef7e0;color:#b06000}.badge--super{background:var(--color-primary-light, #D2E3FC);color:var(--color-primary-dark, #1558B0)}.alert{padding:8px 16px;border-radius:var(--border-radius-md, 8px);font-size:12px;margin-bottom:16px}.alert--error{background:#fce8e6;color:#c5221f;border:1px solid #F5C6C2}.alert--success{background:#e6f4ea;color:#1e7e34;border:1px solid #B7DFC0}.pagination{display:flex;align-items:center;gap:16px;justify-content:center;padding:16px 0}.pagination__spacer{flex:1}.pagination__controls{display:flex;align-items:center;gap:16px}.pagination__info{font-size:12px;color:#80868b;white-space:nowrap}.modal-backdrop{position:fixed;inset:0;background:#00000073;z-index:200}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:201;background:var(--color-card-bg, #FFFFFF);border-radius:var(--border-radius-lg, 12px);box-shadow:0 4px 16px #00000029;width:480px;max-width:calc(100vw - 64px);max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal--wide{width:720px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #E8EAED;flex-shrink:0}.modal__title{font-size:20px;font-weight:700;color:#202124}.modal__close{background:none;border:none;font-size:16px;cursor:pointer;color:#80868b;padding:4px;line-height:1;border-radius:var(--border-radius-sm, 4px)}.modal__close:hover{color:#202124;background:#f8f9fa}.modal__body{padding:24px;overflow-y:auto;flex:1}.modal__footer{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;border-top:1px solid #E8EAED;margin-top:16px}.modal__footer .btn{min-width:120px}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.role-card{background:var(--color-card-bg, #FFFFFF);border-radius:var(--border-radius-lg, 12px);box-shadow:0 2px 8px #0000001f;border:1px solid #E8EAED;padding:24px;display:flex;flex-direction:column;gap:16px;transition:box-shadow .15s ease}.role-card:hover{box-shadow:0 4px 16px #00000029}.role-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.role-card__name{font-size:16px;font-weight:700;color:#202124}.role-card__desc{font-size:12px;color:#80868b;margin-top:2px;line-height:1.4}.role-card__badges{display:flex;flex-direction:column;gap:4px;align-items:flex-end;flex-shrink:0}.role-card__meta{display:flex;gap:16px;font-size:12px;color:#80868b;flex-wrap:wrap}.role-card__actions{display:flex;gap:4px;flex-wrap:wrap;padding-top:8px;border-top:1px solid #E8EAED}.sheet-backdrop{position:fixed;inset:0;z-index:149}.sheet{position:fixed;top:0;right:-400px;width:400px;height:100vh;background:var(--color-card-bg, #FFFFFF);box-shadow:0 4px 16px #00000029;z-index:150;display:flex;flex-direction:column;transition:right .25s ease;overflow:hidden}.sheet--open{right:0}.sheet__header{display:flex;align-items:center;gap:16px;padding:24px;border-bottom:1px solid #E8EAED;flex-shrink:0}.sheet__avatar{width:44px;height:44px;border-radius:50%;background:var(--color-primary-light, #D2E3FC);color:var(--color-primary-dark, #1558B0);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}.sheet__title-wrap{flex:1;min-width:0}.sheet__title{font-size:16px;font-weight:700;color:#202124;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.sheet__close{background:none;border:none;font-size:16px;cursor:pointer;color:#80868b;padding:4px;border-radius:var(--border-radius-sm, 4px);flex-shrink:0}.sheet__close:hover{color:#202124;background:#f8f9fa}.sheet__body{flex:1;overflow-y:auto;padding:24px}.sheet__section{margin-bottom:32px}.sheet__section:last-child{margin-bottom:0}.sheet__section-title{font-size:12px;font-weight:700;color:#80868b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;display:flex;align-items:center;gap:4px}.sheet__section-count{font-weight:400;color:#bdc1c6}.sheet__field{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:8px 0;border-bottom:1px solid #F8F9FA}.sheet__field:last-child{border-bottom:none}.sheet__label{font-size:12px;color:#80868b;flex-shrink:0;padding-top:1px}.sheet__value{font-size:12px;color:#202124;text-align:right;word-break:break-all}.sheet__value--mono{font-family:Courier New,monospace;font-size:11px;color:#5f6368}.sheet__perms-loading,.sheet__perms-empty{font-size:12px;color:#80868b;padding:8px 0}.sheet__footer{padding:16px 24px;border-top:1px solid #E8EAED;flex-shrink:0;background:var(--color-card-bg, #FFFFFF)}.perm-list{display:flex;flex-wrap:wrap;gap:4px;padding-top:4px}.perm-chip{display:inline-block;padding:3px 8px;background:var(--color-primary-light, #D2E3FC);color:var(--color-primary-dark, #1558B0);border-radius:999px;font-size:11px;font-weight:500;text-transform:capitalize;white-space:nowrap}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:4px;max-height:280px;overflow-y:auto;border:1px solid #DADCE0;border-radius:var(--border-radius-md, 8px);padding:8px;background:#f8f9fa}.permission-item{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--border-radius-sm, 4px);cursor:pointer;font-size:12px;color:#3c4043;transition:background .15s ease}.permission-item input[type=checkbox]{cursor:pointer}.permission-item:hover{background:#e8eaed}.toggle-label{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;border:1px solid #DADCE0;border-radius:var(--border-radius-md, 8px);cursor:default;margin-bottom:8px}.toggle-label__text{flex:1;min-width:0}.toggle-label__title{display:block;font-size:14px;font-weight:500;color:#202124;margin-bottom:2px}.toggle-label__hint{display:block;font-size:12px;color:#80868b;line-height:1.4}.toggle{flex-shrink:0;width:44px;height:24px;border-radius:999px;background:#dadce0;position:relative;cursor:pointer;transition:background .15s ease}.toggle--on{background:var(--color-primary, #1A73E8)}.toggle--on .toggle__thumb{transform:translate(20px)}.toggle__thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family-base, "Google Sans", "Roboto", Arial, sans-serif);font-size:14px;background-color:var(--color-surface-bg, #F0F4F9);color:#202124;line-height:1.5;-webkit-font-smoothing:antialiased}h1{font-size:28px;font-weight:700}h2{font-size:22px;font-weight:700}h3{font-size:20px;font-weight:500}h4{font-size:16px;font-weight:500}p{font-size:14px;color:#3c4043}a{color:var(--color-primary, #1A73E8);text-decoration:none}a:hover{text-decoration:underline;color:var(--color-primary-dark, #1558B0)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
