How to apply style for Angular Material 15 elements?
Nothing except ::ng-deep is working for me. According to official docs https://angular.io/guide/component-styles#deprecated-deep--and-ng-deep ::ng-deep is deprecated so I want to avoid using it.
E.g. I want to hide/remove select arrow in mat-select. I have a code like this and it doesn't work without ::ng-deep. I also tried to write the code from the root, css variables but it also didn't work.
HTML
<div class="div-test">
<mat-select [(value)]="selected.id">
<mat-option value="en"></mat-option>
<mat-option value="nl"></mat-option>
</mat-select>
</div>
CSS
.mat-mdc-select-arrow {
display: none;
}

Yes, using
::ng-deepor similar is never a good idea. In your case you could either check if the framework supports this per API, find alternatives or define this style in the global styles with unique class name to avoid conflicts. For example:your-component.html
styles.css (or scss or project defined. global styles)
You could also make your class name more unique like
select-no-arrow. By default, you cannot access the styles of elements inside Angular Material components, because they are encapsulated.