// Select // ******************************************************************************* .form-select { background-clip: padding-box; padding: calc($form-select-padding-y - $input-border-width) calc($form-select-padding-x - $input-border-width); padding-inline-end: calc($form-select-padding-x * 3 - $input-border-width); optgroup { background-color: $card-bg; } &:hover { &:not([disabled]):not([focus]) { border-color: $input-border-hover-color; } } &:disabled { @include ltr-style { background-image: escape-svg($form-select-disabled-indicator); } @include rtl-style { background-image: escape-svg($form-select-disabled-indicator); } } &:focus, .was-validated & { border-width: $input-focus-border-width; @include ltr-style { padding: calc($form-select-padding-y - $input-focus-border-width) calc($form-select-padding-x * 3 - $input-focus-border-width) calc($form-select-padding-y - $input-focus-border-width) calc($form-select-padding-x - $input-focus-border-width); } @include rtl-style { padding: calc($form-select-padding-y - $input-focus-border-width) calc($form-select-padding-x - $input-focus-border-width) calc($form-select-padding-y - $input-focus-border-width) calc($form-select-padding-x * 3 - $input-focus-border-width); } background-position: right calc($form-select-padding-x - 1px) center; } &.form-select-lg { min-height: $input-height-lg; background-size: 24px 24px; padding: calc($form-select-padding-y-lg - $input-border-width) calc($form-select-padding-x-lg - $input-border-width); padding-inline-end: calc($form-select-padding-x-lg * 3 - $input-border-width); &:focus, .was-validated & { @include ltr-style { padding: calc($form-select-padding-y-lg - $input-focus-border-width) calc($form-select-padding-x-lg * 3 - $input-focus-border-width) calc($form-select-padding-y-lg - $input-focus-border-width) calc($form-select-padding-x-lg - $input-focus-border-width); } @include rtl-style { padding: calc($form-select-padding-y-lg - $input-focus-border-width) calc($form-select-padding-x-lg - $input-focus-border-width) calc($form-select-padding-y-lg - $input-focus-border-width) calc($form-select-padding-x-lg * 3 - $input-focus-border-width); } } } &.form-select-sm { min-height: $input-height-sm; background-size: 20px 20px; padding: calc($form-select-padding-y-sm - $input-border-width) calc($form-select-padding-x-sm - $input-border-width); padding-inline-end: calc($form-select-padding-x-sm * 3 - $input-border-width); &:focus, .was-validated & { @include ltr-style { padding: calc($form-select-padding-y-sm - $input-focus-border-width) calc($form-select-padding-x-sm * 3 - $input-focus-border-width) calc($form-select-padding-y-sm - $input-focus-border-width) calc($form-select-padding-x-sm - $input-focus-border-width); } @include rtl-style { padding: calc($form-select-padding-y-sm - $input-focus-border-width) calc($form-select-padding-x-sm - $input-focus-border-width) calc($form-select-padding-y-sm - $input-focus-border-width) calc($form-select-padding-x-sm * 3 - $input-focus-border-width); } } // background-size: 14px 11px; } &[multiple]:focus { padding-inline-end: 0.875rem !important; } } // Multiple select RTL Only @include rtl-only { .form-select { background-image: $form-select-indicator-rtl; background-position: left $form-select-padding-x center; &:focus { background-position: left calc($form-select-padding-x - 1px) center; } &[multiple], &[size]:not([size='1']) { padding-left: 0.9375rem; background-image: none; } } .was-validated .form-select { background-position: left calc($form-select-padding-x - 1px) center; } } @if $dark-style { select.form-select { option { background-color: $card-bg; } } }