.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:var(--radius-lg);box-shadow:0 25px 60px #0003;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border)}.modal-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--secondary);margin:0}.modal-header h2 svg{color:var(--primary)}.close-button{width:40px;height:40px;border-radius:50%;border:none;background:var(--background);color:var(--text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-button:hover{background:#fee2e2;color:#ef4444}.modal-body{flex:1;overflow-y:auto;padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--border);background:var(--background)}.alert{padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem;font-weight:500}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0;display:flex;align-items:center;gap:.5rem}.form-section{margin-bottom:2rem}.form-section:last-child{margin-bottom:0}.form-section h3{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;color:var(--secondary);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.form-section h3 svg{color:var(--primary)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--secondary)}.form-group input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:1rem;color:var(--secondary);transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-group input.disabled{background:var(--background);color:var(--text-light);cursor:not-allowed}.checkbox-group{margin-top:1rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;color:var(--secondary)}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary);cursor:pointer}.current-roles,.available-roles{margin-bottom:1.5rem}.current-roles h4,.available-roles h4{font-size:.9rem;font-weight:600;color:var(--text-light);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.no-roles{color:var(--text-light);font-style:italic;font-size:.95rem}.role-tags{display:flex;flex-wrap:wrap;gap:.75rem}.role-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#e0e7ff;color:#4338ca;border-radius:var(--radius-md);font-weight:600;font-size:.9rem}.role-tag svg:first-child{opacity:.7}.remove-role-button{width:24px;height:24px;border-radius:50%;border:none;background:#ffffff80;color:#4338ca;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-left:.25rem}.remove-role-button:hover{background:#ef4444;color:#fff}.remove-role-button:disabled{cursor:not-allowed;opacity:.5}.role-options{display:flex;flex-wrap:wrap;gap:.75rem}.add-role-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:2px dashed var(--border);border-radius:var(--radius-md);color:var(--text-light);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.add-role-button:hover{border-color:var(--primary);color:var(--primary);background:#f5f3ff}.add-role-button:disabled{cursor:not-allowed;opacity:.5}.cancel-button{padding:.75rem 1.5rem;border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;color:var(--secondary);font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-button:hover{background:var(--background)}.save-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);background:var(--primary);color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease}.save-button:hover{background:#4338ca}.save-button:disabled{cursor:not-allowed;opacity:.7}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:600px){.modal-content{max-height:100vh;border-radius:0}.form-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%;justify-content:center}}
