/* ═══ RL01 CREATE ROLE ═══ */

/* Section accordion */
.rl-section{background:var(--g-surface);border:1px solid var(--g-border);border-radius:8px;margin-bottom:12px;overflow:hidden}
.rl-section-head{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--g-border);cursor:pointer;user-select:none;transition:background .15s}
.rl-section-head:hover{background:var(--g-surface-sub)}
.rl-section-head-left{display:flex;align-items:center;gap:8px}
.rl-section-num{width:22px;height:22px;border-radius:50%;background:var(--g-surface-sec);color:var(--g-text-sec);font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center}
.rl-section-label{font-size:13px;font-weight:600;color:var(--g-text)}
.rl-badge{padding:2px 8px;border-radius:10px;font-size:10px;font-weight:500;letter-spacing:.3px}
.rl-badge-info{background:var(--accent-soft);color:var(--g-text-sec)}
.rl-badge-ok{background:var(--g-ok-bg);color:var(--g-ok)}
.rl-badge-warn{background:var(--g-warn-bg);color:var(--g-warn)}
.rl-badge-err{background:var(--g-err-bg);color:var(--g-err)}
.rl-section-arrow{font-size:10px;color:var(--g-text-muted);transition:transform .2s}
.rl-section.open .rl-section-arrow{transform:rotate(90deg)}
.rl-section-body{display:none;padding:16px}
.rl-section.open .rl-section-body{display:block}

/* Form fields */
.rl-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.rl-form-row-compact{margin-top:8px}
.rl-form-group{display:flex;flex-direction:column;gap:3px}
.rl-lbl{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.8px;color:var(--g-text-muted)}
.rl-inp{padding:8px 10px;font-family:inherit;font-size:13px;border:1px solid var(--g-border);border-radius:6px;background:var(--g-surface);color:var(--g-text);outline:none;transition:border-color .2s}
.rl-inp:focus{border-color:var(--g-create)}
.rl-access-wide{width:100%}
.rl-uppercase{text-transform:uppercase}
select.rl-inp{cursor:pointer}

/* Role type banner */
.rl-banner{padding:10px 14px;border-radius:6px;margin-top:8px;font-size:12px;line-height:1.5;display:flex;align-items:flex-start;gap:8px}
.rl-banner-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.rl-banner-system{background:var(--g-err-bg);border:1px solid var(--g-err-border);color:var(--g-err)}
.rl-banner-tenant{background:var(--g-warn-bg);border:1px solid var(--g-warn-border);color:var(--g-warn)}
.rl-banner-user{background:var(--accent-soft);border:1px solid var(--g-info-border);color:var(--g-text-sec)}

/* Matrix */
.rl-matrix-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.rl-matrix-search{padding:6px 10px;font-family:inherit;font-size:12px;border:1px solid var(--g-border);border-radius:6px;width:200px;outline:none;background:var(--g-surface)}
.rl-matrix-search:focus{border-color:var(--g-create)}
.rl-mod-pill{padding:4px 10px;border-radius:14px;font-size:10px;font-weight:500;cursor:pointer;border:1px solid var(--g-border);background:var(--g-surface);color:var(--g-text-muted);transition:all .15s;letter-spacing:.3px}
.rl-mod-pill:hover{border-color:var(--g-border-strong);color:var(--g-text-sec)}
.rl-mod-pill.active{background:var(--g-consult);border-color:var(--g-consult);color:var(--inverse-text-strong)}

.rl-matrix-wrap{max-height:320px;overflow-y:auto;border:1px solid var(--g-border);border-radius:6px}
.rl-matrix-wrap::-webkit-scrollbar{width:4px}
.rl-matrix-wrap::-webkit-scrollbar-thumb{background:var(--g-border);border-radius:2px}

.rl-matrix{width:100%;border-collapse:collapse;font-size:12px}
.rl-matrix th{padding:6px 8px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--g-text-muted);background:var(--g-surface-sec);border-bottom:1px solid var(--g-border);position:sticky;top:0;z-index:1}
.rl-matrix th.cen{text-align:center}
.rl-matrix td{padding:5px 8px;border-bottom:1px solid var(--g-surface-sub);color:var(--g-text)}
.rl-matrix tr:hover td{background:var(--surface-highlight)}
.rl-matrix td.cen{text-align:center}
.rl-matrix .code-cell{font-weight:600;color:var(--g-text-sec);font-size:11px;letter-spacing:.3px}
.rl-matrix .mod-cell{font-size:10px;padding:2px 6px;border-radius:4px;background:var(--g-surface-sec);color:var(--g-text-muted);font-weight:500;display:inline-block}
.rl-matrix input[type="checkbox"]{accent-color:var(--g-create);width:14px;height:14px;cursor:pointer}

.rl-bypass{padding:20px;text-align:center;background:var(--g-surface-sec);border-radius:6px;color:var(--g-text-muted)}
.rl-bypass strong{color:var(--g-text);display:block;margin-bottom:4px;font-size:14px}

/* Scopes */
.rl-scope-group{margin-bottom:10px}
.rl-scope-head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--g-surface-sec);border-radius:6px;cursor:pointer;user-select:none;margin-bottom:6px}
.rl-scope-head:hover{background:var(--g-surface-sub)}
.rl-scope-head-left{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--g-text)}
.rl-scope-body{display:none;padding:4px 12px 12px}
.rl-scope-group.open .rl-scope-body{display:block}

.rl-scope-field{margin-bottom:8px}
.rl-scope-select-row{display:flex;gap:6px}
.rl-scope-select-row select{flex:1}
.rl-btn-add{padding:7px 12px;font-size:11px;font-weight:500;background:var(--g-create);color:var(--accent-contrast);border:none;border-radius:6px;cursor:pointer;transition:background .15s}
.rl-btn-add:hover{background:var(--g-consult)}

.rl-chip-area{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;min-height:24px}
.rl-chip{display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:14px;font-size:11px;font-weight:500;background:var(--g-surface-sec);color:var(--g-text-sec);border:1px solid var(--g-border)}
.rl-chip-x{cursor:pointer;font-size:12px;color:var(--g-text-muted);transition:color .15s;margin-left:2px}
.rl-chip-x:hover{color:var(--g-err)}

.rl-scope-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:8px}
.rl-scope-card{padding:8px;border-radius:6px;text-align:center;cursor:pointer;border:1px solid var(--g-border);background:var(--g-surface);transition:all .15s;font-size:11px;font-weight:500;color:var(--g-text-muted)}
.rl-scope-card:hover{border-color:var(--g-border-strong);color:var(--g-text-sec)}
.rl-scope-card.on{background:var(--g-consult);border-color:var(--g-consult);color:var(--inverse-text-strong)}
.rl-scope-cards-4{grid-template-columns:repeat(4,1fr)}

/* Summary */
.rl-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rl-summary-item{display:flex;flex-direction:column;gap:2px}
.rl-summary-label{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--g-text-muted)}
.rl-summary-value{font-size:14px;font-weight:600;color:var(--g-text)}
.rl-summary-value-inline{display:flex;align-items:center;height:32px}
.rl-muted-note{font-size:11px;color:var(--g-text-muted);margin-left:6px}
.rl-summary-warn{padding:10px 14px;border-radius:6px;background:var(--g-warn-bg);border:1px solid var(--g-warn-border);color:var(--g-warn);font-size:12px;margin-top:10px;grid-column:1/-1}

/* Action buttons */
.rl-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--g-border)}
.rl-btn{padding:9px 20px;font-family:inherit;font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .15s;letter-spacing:.3px}
.rl-btn-primary{background:var(--g-create);color:var(--accent-contrast);border:none}
.rl-btn-primary:hover{background:var(--g-consult)}
.rl-btn-primary:disabled{opacity:.5;cursor:not-allowed}
.rl-btn-cancel{background:transparent;color:var(--g-text-muted);border:1px solid var(--g-border)}
.rl-btn-cancel:hover{background:var(--g-surface-sub);color:var(--g-text)}

.rl-error{padding:9px 13px;background:var(--g-err-bg);color:var(--g-err);font-size:12px;border-radius:8px;margin-bottom:14px;border:1px solid var(--g-err-border)}
.rl-error-inline{margin:0}
.rl-success{padding:9px 13px;background:var(--g-ok-bg);color:var(--g-ok);font-size:12px;border-radius:8px;margin-bottom:14px;border:1px solid var(--g-ok-border)}

.rl-dep-hint{font-size:10px;color:var(--g-text-muted);font-style:normal}
