@keenmate/web-multiselect 1.0.0-rc05 → 1.0.0-rc08

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/style.css CHANGED
@@ -1 +1 @@
1
- @charset "UTF-8";multi-select:not(:defined){display:block;min-height:2.5rem;color:transparent!important;background:transparent}.ml-wrapper{display:flex;flex-direction:column;align-items:stretch}.ml-wrapper--inline{flex-direction:row;align-items:flex-start}.ml{position:relative;width:100%}.ml__input-wrapper{position:relative;display:flex;align-items:center}.ml__input{width:100%;padding:var(--ml-input-padding, .5rem .75rem);padding-right:var(--ml-input-padding-right, 2.5rem);font-size:var(--ml-input-font-size, .875rem);border:var(--ml-input-border-style, 1px solid #d1d5db);border-radius:var(--ml-input-border-radius, .375rem);background:var(--ml-input-bg, #ffffff);color:var(--ml-input-text, #111827);cursor:pointer;transition:border-color var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__input:focus{outline:none;border-color:var(--ml-input-focus-border-color, #3b82f6)}.ml__input::placeholder{color:var(--ml-input-placeholder-color, #6b7280);opacity:0;transition:opacity var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}:host([data-ready]) .ml__input::placeholder{opacity:var(--ml-placeholder-opacity, .6)}.ml__toggle{position:absolute;right:var(--ml-toggle-right, .75rem);top:50%;transform:var(--ml-transform-center-y, translateY(-50%));pointer-events:none;color:var(--ml-toggle-color, #6b7280);transition:transform var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml--open .ml__toggle{transform:var(--ml-transform-center-y, translateY(-50%)) rotate(var(--ml-transform-rotate-180, 180deg))}.ml__count-badge{position:absolute;right:var(--ml-count-badge-offset, 2rem);top:50%;transform:var(--ml-transform-center-y, translateY(-50%));padding:var(--ml-count-badge-padding, .125rem .25rem);background:var(--ml-count-badge-bg, #3b82f6);color:var(--ml-count-badge-color, #ffffff);font-size:var(--ml-count-badge-font-size, .75rem);font-weight:var(--ml-count-badge-font-weight, 600);border-radius:var(--ml-count-badge-border-radius, .25rem);cursor:pointer;transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-badge:hover{background:var(--ml-count-badge-bg-hover, #2563eb);transform:var(--ml-transform-center-y, translateY(-50%)) scale(var(--ml-transform-scale-hover, 1.1))}.ml__hint{display:none;position:absolute;z-index:var(--ml-z-index-popover, 10000);padding:var(--ml-hint-padding, .5rem .75rem);background:var(--ml-hint-bg, #ffffff);border:var(--ml-hint-border, 1px solid #e5e7eb);border-radius:var(--ml-hint-border-radius, .375rem);box-shadow:var(--ml-hint-box-shadow, 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1));font-size:var(--ml-hint-font-size, .75rem);color:var(--ml-hint-color, #6b7280);line-height:var(--ml-line-height-relaxed, 1.4);max-width:100%}.ml__hint--visible{display:block}.ml__dropdown{display:none;position:absolute;z-index:var(--ml-z-index-dropdown, 9999);background:var(--ml-dropdown-bg, #ffffff);border:var(--ml-dropdown-border, 1px solid #e5e7eb);border-radius:var(--ml-dropdown-border-radius, .375rem);box-shadow:var(--ml-dropdown-box-shadow, 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1));max-height:var(--ml-dropdown-max-height, 20rem);overflow-y:auto;color:var(--ml-dropdown-color, #111827)}.ml__dropdown--visible{display:block}.ml__actions{display:flex;gap:var(--ml-actions-gap, .25rem);padding:var(--ml-actions-padding, .5rem);border-bottom:var(--ml-actions-border-bottom, 1px solid #e5e7eb)}.ml__actions--sticky{position:sticky;top:0;z-index:var(--ml-z-index-sticky, 1);background:var(--ml-actions-bg, #ffffff)}.ml__action-btn{flex:1;padding:var(--ml-action-btn-padding, .25rem .5rem);font-size:var(--ml-action-btn-font-size, .75rem);border:var(--ml-action-btn-border, 1px solid #e5e7eb);border-radius:var(--ml-action-btn-border-radius, .25rem);background:var(--ml-action-btn-bg, transparent);color:var(--ml-action-btn-color, inherit);cursor:pointer;transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__action-btn:hover{background:var(--ml-action-btn-bg-hover, #f3f4f6);border-color:var(--ml-action-btn-border-color-hover, #3b82f6)}.ml__action-btn:active{transform:scale(var(--ml-transform-scale-active, .98))}.ml__options{padding:var(--ml-options-padding, .25rem 0)}.ml__group+.ml__group{border-top:var(--ml-group-border-top, 1px solid #e5e7eb);margin-top:var(--ml-group-margin-top, .25rem);padding-top:var(--ml-group-padding-top, .25rem)}.ml__group-label{padding:var(--ml-group-label-padding, .25rem .75rem);font-size:var(--ml-group-label-font-size, .75rem);font-weight:var(--ml-group-label-font-weight, 600);color:var(--ml-group-label-color, #6b7280);text-transform:var(--ml-group-label-transform, uppercase);letter-spacing:var(--ml-group-label-letter-spacing, .05em)}.ml__option{display:flex;align-items:flex-start;gap:var(--ml-option-gap, .5rem);padding:var(--ml-option-padding, .5rem .75rem);cursor:pointer;transition:background-color var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__option:hover{background:var(--ml-option-bg-hover, #f9fafb)}.ml__option--focused{background:var(--ml-option-bg-focused, #f9fafb);outline:var(--ml-option-outline-focused, 2px solid #3b82f6);outline-offset:var(--ml-option-focus-outline-offset, -2px)}.ml__option--selected{background:var(--ml-option-bg-selected, rgba(59, 130, 246, .1))}.ml__option--disabled{opacity:var(--ml-disabled-opacity, .5);cursor:not-allowed}.ml__option--disabled:hover{background:var(--ml-option-bg, transparent)}.ml__checkbox{flex-shrink:0;margin-top:var(--ml-checkbox-margin-top, .125rem);cursor:pointer}.ml__option--disabled .ml__checkbox{cursor:not-allowed}.ml__option-content{flex:1;display:flex;align-items:flex-start;gap:var(--ml-option-content-gap, .5rem);min-width:0}.ml__option-icon{flex-shrink:0;width:var(--ml-option-icon-size, 1.25rem);height:var(--ml-option-icon-size, 1.25rem);display:flex;align-items:center;justify-content:center;font-size:var(--ml-option-icon-font-size, 1rem)}.ml__option-icon svg{width:100%;height:100%;fill:currentColor}.ml__option-text{flex:1;min-width:0}.ml__option-title{font-size:var(--ml-option-title-font-size, .875rem);color:var(--ml-option-title-color, inherit);line-height:var(--ml-line-height-relaxed, 1.4)}.ml__option-title mark{background:var(--ml-option-mark-bg, rgba(59, 130, 246, .2));color:var(--ml-option-mark-color, inherit);font-weight:var(--ml-option-mark-font-weight, 600)}.ml__option-subtitle{margin-top:var(--ml-option-subtitle-margin-top, .25rem);font-size:var(--ml-option-subtitle-font-size, .75rem);color:var(--ml-option-subtitle-color, #6b7280);line-height:var(--ml-option-subtitle-line-height, 1.3)}.ml__empty{padding:var(--ml-empty-padding, 1rem .75rem);text-align:center;font-size:var(--ml-empty-font-size, .875rem);color:var(--ml-empty-color, #6b7280)}.ml__loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--ml-loader-padding, 1rem);gap:var(--ml-loader-gap, .5rem)}.ml__loading-text{font-size:var(--ml-loading-text-font-size, .875rem);color:var(--ml-loading-text-color, #6b7280)}.ml__pills{display:flex;flex-wrap:wrap;gap:var(--ml-pills-gap, .5rem);padding:0}.ml__pills:empty{display:none}.ml__pills--bottom{margin-top:var(--ml-pills-margin-bottom, .5rem)}.ml__pills--top{margin-bottom:var(--ml-pills-margin-top, .5rem);order:var(--ml-order-first, -1)}.ml__pills--left{order:var(--ml-order-first, -1);margin-right:var(--ml-pills-margin-left, .25rem);justify-content:flex-end}.ml__pills--right{margin-left:var(--ml-pills-margin-right, .25rem);justify-content:flex-start}.ml__count-display{display:flex;align-items:center}.ml__count-display:empty{display:none}.ml__count-display--bottom{margin-top:var(--ml-count-display-margin-bottom, .5rem)}.ml__count-display--top{margin-bottom:var(--ml-count-display-margin-top, .5rem);order:var(--ml-order-first, -1)}.ml__count-display--left{order:var(--ml-order-first, -1);margin-right:var(--ml-count-display-margin-left, .5rem);justify-content:flex-start}.ml__count-display--right{margin-left:var(--ml-count-display-margin-right, .5rem);justify-content:flex-end}.ml__count-badge-wrapper{display:inline-flex;align-items:center;gap:var(--ml-count-badge-wrapper-gap, .25rem);background:var(--ml-count-badge-wrapper-bg, transparent);border:var(--ml-count-badge-wrapper-border, 1px solid #e5e7eb);border-radius:var(--ml-count-badge-wrapper-border-radius, .25rem);padding:var(--ml-count-badge-wrapper-padding, .25rem .5rem);transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-badge-wrapper:hover{background:var(--ml-count-badge-wrapper-bg-hover, #f9fafb);border-color:var(--ml-count-badge-wrapper-border-color-hover, #3b82f6)}.ml__count-text{display:inline-flex;align-items:center;background:var(--ml-count-text-bg, transparent);border:var(--ml-count-text-border, none);padding:0;font-size:var(--ml-count-text-font-size, .875rem);color:var(--ml-count-text-color, #111827);cursor:pointer;transition:color var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-clear{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:var(--ml-count-clear-size, 1rem);height:var(--ml-count-clear-size, 1rem);padding:0;border:none;background:var(--ml-count-clear-bg, transparent);color:var(--ml-count-clear-color, #6b7280);font-size:var(--ml-count-clear-font-size, 1.125rem);line-height:var(--ml-line-height-none, 1);cursor:pointer;border-radius:var(--ml-count-clear-border-radius, 50%);transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-clear:hover{background:var(--ml-count-clear-bg-hover, rgba(59, 130, 246, .2));color:var(--ml-count-clear-color-hover, #3b82f6)}.ml__count-clear:before{content:var(--ml-icon-clear, "×")}.ml__pill{display:inline-flex;align-items:center;height:var(--ml-pill-height, 1.5rem);font-size:var(--ml-pill-font-size, .75rem);font-weight:var(--ml-pill-font-weight, 600);line-height:var(--ml-line-height-none, 1);border-radius:var(--ml-pill-border-radius, .375rem);overflow:hidden;max-width:100%}.ml__pill-text{display:flex;align-items:center;height:100%;padding:var(--ml-pill-text-padding, 0 .5rem);background:var(--ml-pill-text-bg, #eff6ff);color:var(--ml-pill-text-color, #3b82f6);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background-color var(--ml-transition-normal, .2s) ease}.ml__pill-remove{display:flex;align-items:center;justify-content:center;width:var(--ml-pill-remove-width, 1.5rem);height:100%;flex-shrink:0;background:var(--ml-pill-remove-bg, #3b82f6);color:var(--ml-pill-remove-color, #ffffff);border:var(--ml-pill-remove-border, none);cursor:pointer;transition:background-color var(--ml-transition-normal, .2s) ease;font-size:var(--ml-pill-remove-font-size, .75rem)}.ml__pill-remove:hover{background:var(--ml-pill-remove-bg-hover, #2563eb)}.ml__pill-remove:focus{outline:none;box-shadow:var(--ml-pill-remove-box-shadow-focus, 0 0 0 2px rgba(59, 130, 246, .5))}.ml__pill-remove:before{content:var(--ml-icon-remove, "×");font-size:var(--ml-font-size-base, 1rem);line-height:var(--ml-line-height-none, 1)}.ml__pill--more{cursor:pointer}.ml__pill--more .ml__pill-text{background:var(--ml-more-badge-bg, #eff6ff);font-weight:var(--ml-pill-font-weight, 600)}.ml__pill--more:hover .ml__pill-text{background:var(--ml-more-badge-hover-bg, #ffffff)}.ml__pill--more:active .ml__pill-text{background:var(--ml-more-badge-active-bg, #e0f2fe)}.ml__pill-tooltip{position:fixed;z-index:var(--ml-tooltip-z-index, 10000);opacity:0;visibility:hidden;transition:opacity var(--ml-transition-normal, .2s) ease,visibility var(--ml-transition-normal, .2s) ease;background:var(--ml-tooltip-bg, #333);color:var(--ml-tooltip-color, #fff);padding:var(--ml-tooltip-padding, .5rem .75rem);border-radius:var(--ml-tooltip-border-radius, .375rem);font-size:var(--ml-tooltip-font-size, .875rem);line-height:var(--ml-line-height-relaxed, 1.4);max-width:var(--ml-tooltip-max-width, 20rem);word-wrap:break-word;white-space:pre-wrap;box-shadow:var(--ml-tooltip-shadow, 0 2px 8px rgba(0, 0, 0, .15));pointer-events:none}.ml__pill-tooltip--visible{opacity:1;visibility:visible}.ml__selected-popover{display:none;position:absolute;z-index:var(--ml-z-index-popover, 10000);background:var(--ml-selected-popover-bg, #ffffff);border:var(--ml-selected-popover-border, 1px solid #e5e7eb);border-radius:var(--ml-selected-popover-border-radius, .375rem);box-shadow:var(--ml-selected-popover-box-shadow, 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1));width:var(--ml-selected-popover-width, 20rem);max-height:var(--ml-selected-popover-max-height, 20rem);overflow:hidden}.ml__selected-popover--visible{display:flex;flex-direction:column}.ml__selected-popover-header{display:flex;align-items:center;justify-content:space-between;padding:var(--ml-selected-popover-header-padding, .5rem .75rem);background:var(--ml-selected-popover-header-bg, rgba(59, 130, 246, .1));border-bottom:var(--ml-selected-popover-header-border-bottom, 1px solid #e5e7eb);font-size:var(--ml-selected-popover-header-font-size, .875rem);font-weight:var(--ml-selected-popover-header-font-weight, 600);color:var(--ml-selected-popover-header-color, #111827)}.ml__selected-popover-close{display:flex;align-items:center;justify-content:center;width:var(--ml-popover-close-size, 1.5rem);height:var(--ml-popover-close-size, 1.5rem);padding:0;border:none;background:var(--ml-selected-popover-close-bg, transparent);color:var(--ml-selected-popover-close-color, #6b7280);font-size:var(--ml-selected-popover-close-font-size, 1.25rem);line-height:var(--ml-line-height-none, 1);cursor:pointer;border-radius:var(--ml-selected-popover-close-border-radius, 50%);transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__selected-popover-close:hover{background:var(--ml-selected-popover-close-bg-hover, rgba(59, 130, 246, .2));color:var(--ml-selected-popover-close-color-hover, #3b82f6)}.ml__selected-popover-body{display:flex;flex-direction:column;gap:var(--ml-selected-popover-body-gap, .25rem);padding:var(--ml-selected-popover-body-padding, .5rem);overflow-y:auto;max-height:var(--ml-selected-popover-body-max-height, 18rem)}.ml__selected-popover-body .ml__pill{width:100%}.ml__selected-popover-body .ml__pill-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.ml--rtl .ml__input-wrapper{direction:rtl}.ml--rtl .ml__input{text-align:right;padding-left:var(--ml-input-padding-right, 2.5rem);padding-right:var(--ml-input-padding-h, .75rem)}.ml--rtl .ml__toggle{left:var(--ml-toggle-right, .75rem)!important;right:auto!important}.ml--rtl .ml__count-badge{left:var(--ml-count-badge-offset, 2rem)!important;right:auto!important}.ml--rtl .ml__dropdown{direction:rtl;text-align:right}.ml--rtl .ml__option{flex-direction:row-reverse}.ml--rtl .ml__checkbox{margin-left:var(--ml-spacing-sm, .5rem);margin-right:0}.ml--rtl .ml__option-content{text-align:right}.ml--rtl .ml__option-icon{margin-left:var(--ml-spacing-xs, .25rem);margin-right:0}.ml--rtl .ml__pills{direction:rtl}.ml--rtl .ml__pill{flex-direction:row-reverse}.ml--rtl .ml__pill-remove{border-radius:var(--ml-pill-remove-border-radius-rtl, .375rem) 0 0 var(--ml-pill-remove-border-radius-rtl, .375rem);border-left:var(--ml-pill-remove-border, none);border-right:none}.ml--rtl .ml__pill-text{border-radius:0 var(--ml-pill-text-border-radius-rtl, .375rem) var(--ml-pill-text-border-radius-rtl, .375rem) 0}.ml--rtl .ml__count-display{direction:rtl}.ml--rtl .ml__count-badge-wrapper{flex-direction:row-reverse}.ml--rtl .ml__selected-popover{direction:rtl;text-align:right}.ml--rtl .ml__actions{direction:rtl}.ml--rtl .ml__group-label,.ml--rtl .ml__empty{text-align:right}.ml--rtl .ml__hint{direction:rtl;text-align:right}.ml--xs .ml__input{font-size:var(--ml-font-size-xs, .75rem)}.ml--xs .ml__option{padding:var(--ml-spacing-xs, .25rem) var(--ml-spacing-sm, .5rem)}.ml--xs .ml__option-title{font-size:var(--ml-font-size-xs, .75rem)}.ml--xs .ml__pill{font-size:var(--ml-font-size-2xs, .625rem)}.ml--sm .ml__input,.ml--sm .ml__option-title{font-size:var(--ml-font-size-xs, .75rem)}.ml--lg .ml__input,.ml--lg .ml__option-title{font-size:var(--ml-font-size-base, 1rem)}.ml--lg .ml__pill{font-size:var(--ml-font-size-sm, .875rem)}.ml--xl .ml__input,.ml--xl .ml__option-title{font-size:var(--ml-font-size-lg, 1.125rem)}.ml--xl .ml__pill{font-size:var(--ml-font-size-base, 1rem)}.ml--disabled .ml__input{opacity:var(--ml-disabled-input-opacity, .6);cursor:not-allowed;background:var(--ml-input-bg-disabled, rgba(107, 114, 128, .05))}.ml--disabled .ml__toggle{opacity:var(--ml-disabled-input-opacity, .6)}.ml--no-checkboxes .ml__option{gap:0;padding-left:var(--ml-option-padding-h, .75rem)}.ml--no-checkboxes .ml__option-content{padding-left:0}.ml-debug-info{margin-top:.25rem;padding:.25rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.75rem;color:#111827}.ml-debug-info details summary{cursor:pointer;font-weight:600;color:#2563eb;-webkit-user-select:none;user-select:none;padding:.25rem;border-radius:.25rem}.ml-debug-info details summary:hover{background-color:#f3f4f6}.ml-debug-info details summary:focus{outline:2px solid #3b82f6;outline-offset:2px}.ml-debug-info .ml-debug-stats{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem;padding:.25rem;background-color:#fff;border-radius:.25rem}.ml-debug-info .ml-debug-stats span{display:flex;justify-content:space-between;padding:2px 4px;font-family:monospace;font-size:.625rem}.ml-debug-info .ml-debug-stats span:before{content:"•";margin-right:.25rem;color:#3b82f6}
1
+ @charset "UTF-8";:host{--ml-accent-color: #3b82f6;--ml-accent-color-hover: #2563eb;--ml-accent-color-active: #1d4ed8;--ml-text-primary: #111827;--ml-text-secondary: #6b7280;--ml-text-white: #ffffff;--ml-primary-bg: #f3f4f6;--ml-primary-bg-hover: #e5e7eb;--ml-border-color: #e5e7eb;--ml-input-padding: .5rem .75rem;--ml-input-padding-right: 2.5rem;--ml-input-font-size: .875rem;--ml-input-border-style: 1px solid #d1d5db;--ml-input-border-radius: .375rem;--ml-input-bg: #ffffff;--ml-input-text: #111827;--ml-input-focus-border-color: #3b82f6;--ml-input-placeholder-color: #6b7280;--ml-input-bg-disabled: rgba(107, 114, 128, .05);--ml-toggle-right: .75rem;--ml-toggle-color: #6b7280;--ml-transform-center-y: translateY(-50%);--ml-transform-rotate-180: 180deg;--ml-count-badge-offset: 2rem;--ml-count-badge-padding: .125rem .25rem;--ml-count-badge-bg: #3b82f6;--ml-count-badge-color: #ffffff;--ml-count-badge-font-size: .75rem;--ml-count-badge-font-weight: 600;--ml-count-badge-border-radius: .25rem;--ml-count-badge-bg-hover: #2563eb;--ml-transform-scale-hover: 1.1;--ml-hint-padding: .5rem .75rem;--ml-hint-bg: #ffffff;--ml-hint-border: 1px solid #e5e7eb;--ml-hint-border-radius: .375rem;--ml-hint-box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--ml-hint-font-size: .75rem;--ml-hint-color: #6b7280;--ml-line-height-relaxed: 1.4;--ml-dropdown-bg: #ffffff;--ml-dropdown-border: 1px solid #e5e7eb;--ml-dropdown-border-radius: .375rem;--ml-dropdown-box-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--ml-dropdown-max-height: 20rem;--ml-dropdown-color: #111827;--ml-z-index-dropdown: 9999;--ml-z-index-sticky: 1;--ml-actions-gap: .25rem;--ml-actions-padding: .5rem;--ml-actions-border-bottom: 1px solid #e5e7eb;--ml-actions-bg: #ffffff;--ml-action-btn-padding: .25rem .5rem;--ml-action-btn-font-size: .75rem;--ml-action-btn-border: 1px solid #e5e7eb;--ml-action-btn-border-radius: .25rem;--ml-action-btn-bg: transparent;--ml-action-btn-color: inherit;--ml-action-btn-bg-hover: #f3f4f6;--ml-action-btn-border-color-hover: #3b82f6;--ml-transform-scale-active: .98;--ml-options-padding: .25rem 0;--ml-group-border-top: 1px solid #e5e7eb;--ml-group-margin-top: .25rem;--ml-group-padding-top: .25rem;--ml-group-label-padding: .25rem .75rem;--ml-group-label-font-size: .75rem;--ml-group-label-font-weight: 600;--ml-group-label-color: #6b7280;--ml-group-label-transform: uppercase;--ml-group-label-letter-spacing: .05em;--ml-option-gap: .5rem;--ml-option-padding: .5rem .75rem;--ml-option-padding-h: .75rem;--ml-option-bg: transparent;--ml-option-bg-hover: #f9fafb;--ml-option-bg-focused: #f9fafb;--ml-option-outline-focused: 2px solid #3b82f6;--ml-option-focus-outline-offset: -2px;--ml-option-bg-matched: rgba(59, 130, 246, .08);--ml-option-border-matched: 3px solid rgba(59, 130, 246, .4);--ml-option-bg-selected: rgba(59, 130, 246, .1);--ml-disabled-opacity: .5;--ml-option-content-gap: .5rem;--ml-option-icon-size: 1.25rem;--ml-option-icon-font-size: 1rem;--ml-option-title-font-size: .875rem;--ml-option-title-color: inherit;--ml-option-mark-bg: rgba(59, 130, 246, .2);--ml-option-mark-color: inherit;--ml-option-mark-font-weight: 600;--ml-option-subtitle-margin-top: .25rem;--ml-option-subtitle-font-size: .75rem;--ml-option-subtitle-color: #6b7280;--ml-option-subtitle-line-height: 1.3;--ml-checkbox-margin-top: .125rem;--ml-empty-padding: 1rem .75rem;--ml-empty-font-size: .875rem;--ml-empty-color: #6b7280;--ml-loader-padding: 1rem;--ml-loader-gap: .5rem;--ml-loading-text-font-size: .875rem;--ml-loading-text-color: #6b7280;--ml-pills-gap: .5rem;--ml-pills-margin-bottom: .5rem;--ml-pills-margin-top: .5rem;--ml-pills-margin-left: .25rem;--ml-pills-margin-right: .25rem;--ml-pill-gap: .5rem;--ml-pill-height: 1.5rem;--ml-pill-font-size: .75rem;--ml-pill-font-weight: 600;--ml-pill-border-radius: .375rem;--ml-pill-bg: #eff6ff;--ml-pill-bg-hover: #ffffff;--ml-pill-bg-active: #e0f2fe;--ml-order-first: -1;--ml-pill-text-padding: 0 .5rem;--ml-pill-text-bg: #eff6ff;--ml-pill-text-color: #3b82f6;--ml-pill-remove-width: 1.5rem;--ml-pill-remove-bg: #3b82f6;--ml-pill-remove-color: #ffffff;--ml-pill-remove-border: none;--ml-pill-remove-font-size: .75rem;--ml-pill-remove-bg-hover: #2563eb;--ml-pill-remove-box-shadow-focus: 0 0 0 2px rgba(59, 130, 246, .5);--ml-icon-remove: "×";--ml-more-badge-bg: #eff6ff;--ml-more-badge-hover-bg: #ffffff;--ml-more-badge-active-bg: #e0f2fe;--ml-count-display-margin-bottom: .5rem;--ml-count-display-margin-top: .5rem;--ml-count-display-margin-left: .5rem;--ml-count-display-margin-right: .5rem;--ml-count-badge-wrapper-bg: transparent;--ml-count-badge-wrapper-border: 1px solid #e5e7eb;--ml-count-badge-wrapper-border-radius: .25rem;--ml-count-badge-wrapper-padding: .25rem .5rem;--ml-count-badge-wrapper-gap: .25rem;--ml-count-badge-wrapper-bg-hover: #f9fafb;--ml-count-badge-wrapper-border-color-hover: #3b82f6;--ml-count-text-bg: transparent;--ml-count-text-border: none;--ml-count-text-font-size: .875rem;--ml-count-text-color: #111827;--ml-count-clear-size: 1rem;--ml-count-clear-bg: transparent;--ml-count-clear-color: #6b7280;--ml-count-clear-font-size: 1.125rem;--ml-count-clear-border-radius: 50%;--ml-count-clear-bg-hover: rgba(59, 130, 246, .2);--ml-count-clear-color-hover: #3b82f6;--ml-icon-clear: "×";--ml-tooltip-bg: #333;--ml-tooltip-color: #fff;--ml-tooltip-padding: .5rem .75rem;--ml-tooltip-border-radius: .375rem;--ml-tooltip-font-size: .875rem;--ml-tooltip-max-width: 20rem;--ml-tooltip-shadow: 0 2px 8px rgba(0, 0, 0, .15);--ml-tooltip-z-index: 10000;--ml-z-index-popover: 10000;--ml-selected-popover-width: 20rem;--ml-selected-popover-max-height: 20rem;--ml-selected-popover-bg: #ffffff;--ml-selected-popover-border: 1px solid #e5e7eb;--ml-selected-popover-border-radius: .375rem;--ml-selected-popover-box-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--ml-selected-popover-header-padding: .5rem .75rem;--ml-selected-popover-header-bg: rgba(59, 130, 246, .1);--ml-selected-popover-header-border-bottom: 1px solid #e5e7eb;--ml-selected-popover-header-font-size: .875rem;--ml-selected-popover-header-font-weight: 600;--ml-selected-popover-header-color: #111827;--ml-popover-close-size: 1.5rem;--ml-selected-popover-close-bg: transparent;--ml-selected-popover-close-color: #6b7280;--ml-selected-popover-close-font-size: 1.25rem;--ml-selected-popover-close-border-radius: 50%;--ml-selected-popover-close-bg-hover: rgba(59, 130, 246, .2);--ml-selected-popover-close-color-hover: #3b82f6;--ml-selected-popover-body-gap: .25rem;--ml-selected-popover-body-padding: .5rem;--ml-selected-popover-body-max-height: 18rem;--ml-font-size-2xs: .625rem;--ml-font-size-xs: .75rem;--ml-font-size-sm: .875rem;--ml-font-size-base: 1rem;--ml-font-size-lg: 1.125rem;--ml-font-weight-medium: 500;--ml-font-weight-semibold: 600;--ml-line-height-none: 1;--ml-spacing-xs: .25rem;--ml-spacing-sm: .5rem;--ml-spacing-md: .75rem;--ml-spacing-lg: 1rem;--ml-transition-fast: .15s;--ml-transition-normal: .2s;--ml-easing-snappy: cubic-bezier(.4, 0, .2, 1);--ml-placeholder-opacity: .6;--ml-disabled-input-opacity: .6}multi-select:not(:defined){display:block;min-height:2.5rem;color:transparent!important;background:transparent}.ml-wrapper{display:flex;flex-direction:column;align-items:stretch}.ml-wrapper--inline{flex-direction:row;align-items:flex-start}.ml{position:relative;width:100%}.ml__input-wrapper{position:relative;display:flex;align-items:center}.ml__input{width:100%;padding:var(--ml-input-padding, .5rem .75rem);padding-right:var(--ml-input-padding-right, 2.5rem);font-size:var(--ml-input-font-size, .875rem);border:var(--ml-input-border-style, 1px solid #d1d5db);border-radius:var(--ml-input-border-radius, .375rem);background:var(--ml-input-bg, #ffffff);color:var(--ml-input-text, #111827);cursor:pointer;transition:border-color var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__input:focus{outline:none;border-color:var(--ml-input-focus-border-color, #3b82f6)}.ml__input::placeholder{color:var(--ml-input-placeholder-color, #6b7280);opacity:0;transition:opacity var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}:host([data-ready]) .ml__input::placeholder{opacity:var(--ml-placeholder-opacity, .6)}.ml__toggle{position:absolute;right:var(--ml-toggle-right, .75rem);top:50%;transform:var(--ml-transform-center-y, translateY(-50%));pointer-events:none;color:var(--ml-toggle-color, #6b7280);transition:transform var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml--open .ml__toggle{transform:var(--ml-transform-center-y, translateY(-50%)) rotate(var(--ml-transform-rotate-180, 180deg))}.ml__count-badge{position:absolute;right:var(--ml-count-badge-offset, 2rem);top:50%;transform:var(--ml-transform-center-y, translateY(-50%));padding:var(--ml-count-badge-padding, .125rem .25rem);background:var(--ml-count-badge-bg, #3b82f6);color:var(--ml-count-badge-color, #ffffff);font-size:var(--ml-count-badge-font-size, .75rem);font-weight:var(--ml-count-badge-font-weight, 600);border-radius:var(--ml-count-badge-border-radius, .25rem);cursor:pointer;transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-badge:hover{background:var(--ml-count-badge-bg-hover, #2563eb);transform:var(--ml-transform-center-y, translateY(-50%)) scale(var(--ml-transform-scale-hover, 1.1))}.ml__hint{display:none;position:absolute;z-index:var(--ml-z-index-popover, 10000);padding:var(--ml-hint-padding, .5rem .75rem);background:var(--ml-hint-bg, #ffffff);border:var(--ml-hint-border, 1px solid #e5e7eb);border-radius:var(--ml-hint-border-radius, .375rem);box-shadow:var(--ml-hint-box-shadow, 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1));font-size:var(--ml-hint-font-size, .75rem);color:var(--ml-hint-color, #6b7280);line-height:var(--ml-line-height-relaxed, 1.4);max-width:100%}.ml__hint--visible{display:block}.ml__dropdown{display:none;position:absolute;z-index:var(--ml-z-index-dropdown, 9999);background:var(--ml-dropdown-bg, #ffffff);border:var(--ml-dropdown-border, 1px solid #e5e7eb);border-radius:var(--ml-dropdown-border-radius, .375rem);box-shadow:var(--ml-dropdown-box-shadow, 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1));max-height:var(--ml-dropdown-max-height, 20rem);overflow-y:auto;overscroll-behavior:contain;touch-action:pan-y;-webkit-overflow-scrolling:touch;color:var(--ml-dropdown-color, #111827)}.ml__dropdown--visible{display:block}.ml__dropdown--virtual{overflow-y:visible;max-height:none}.ml__actions{display:flex;gap:var(--ml-actions-gap, .25rem);padding:var(--ml-actions-padding, .5rem);border-bottom:var(--ml-actions-border-bottom, 1px solid #e5e7eb)}.ml__actions--sticky{position:sticky;top:0;z-index:var(--ml-z-index-sticky, 1);background:var(--ml-actions-bg, #ffffff)}.ml__action-btn{flex:1;padding:var(--ml-action-btn-padding, .25rem .5rem);font-size:var(--ml-action-btn-font-size, .75rem);border:var(--ml-action-btn-border, 1px solid #e5e7eb);border-radius:var(--ml-action-btn-border-radius, .25rem);background:var(--ml-action-btn-bg, transparent);color:var(--ml-action-btn-color, inherit);cursor:pointer;transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__action-btn:hover{background:var(--ml-action-btn-bg-hover, #f3f4f6);border-color:var(--ml-action-btn-border-color-hover, #3b82f6)}.ml__action-btn:active{transform:scale(var(--ml-transform-scale-active, .98))}.ml__options{padding:var(--ml-options-padding, .25rem 0)}.ml__options--virtual .ml__option{height:var(--ml-option-height, 50px);min-height:var(--ml-option-height, 50px);max-height:var(--ml-option-height, 50px);overflow:hidden;box-sizing:border-box}.ml__group+.ml__group{border-top:var(--ml-group-border-top, 1px solid #e5e7eb);margin-top:var(--ml-group-margin-top, .25rem);padding-top:var(--ml-group-padding-top, .25rem)}.ml__group-label{padding:var(--ml-group-label-padding, .25rem .75rem);font-size:var(--ml-group-label-font-size, .75rem);font-weight:var(--ml-group-label-font-weight, 600);color:var(--ml-group-label-color, #6b7280);text-transform:var(--ml-group-label-transform, uppercase);letter-spacing:var(--ml-group-label-letter-spacing, .05em)}.ml__option{display:flex;align-items:flex-start;gap:var(--ml-option-gap, .5rem);padding:var(--ml-option-padding, .5rem .75rem);cursor:pointer;transition:background-color var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__option:hover{background:var(--ml-option-bg-hover, #f9fafb)}.ml__option--focused{background:var(--ml-option-bg-focused, #f9fafb);outline:var(--ml-option-outline-focused, 2px solid #3b82f6);outline-offset:var(--ml-option-focus-outline-offset, -2px)}.ml__option--matched{background:var(--ml-option-bg-matched, rgba(59, 130, 246, .08));border-left:var(--ml-option-border-matched, 3px solid rgba(59, 130, 246, .4))}.ml__option--selected{background:var(--ml-option-bg-selected, rgba(59, 130, 246, .1))}.ml__option--disabled{opacity:var(--ml-disabled-opacity, .5);cursor:not-allowed}.ml__option--disabled:hover{background:var(--ml-option-bg, transparent)}.ml__checkbox{flex-shrink:0;margin-top:var(--ml-checkbox-margin-top, .125rem);cursor:pointer}.ml__option--disabled .ml__checkbox{cursor:not-allowed}.ml__option-content{flex:1;display:flex;align-items:flex-start;gap:var(--ml-option-content-gap, .5rem);min-width:0}.ml__option-icon{flex-shrink:0;width:var(--ml-option-icon-size, 1.25rem);height:var(--ml-option-icon-size, 1.25rem);display:flex;align-items:center;justify-content:center;font-size:var(--ml-option-icon-font-size, 1rem)}.ml__option-icon svg{width:100%;height:100%;fill:currentColor}.ml__option-text{flex:1;min-width:0}.ml__option-title{font-size:var(--ml-option-title-font-size, .875rem);color:var(--ml-option-title-color, inherit);line-height:var(--ml-line-height-relaxed, 1.4)}.ml__option-title mark{background:var(--ml-option-mark-bg, rgba(59, 130, 246, .2));color:var(--ml-option-mark-color, inherit);font-weight:var(--ml-option-mark-font-weight, 600)}.ml__option-subtitle{margin-top:var(--ml-option-subtitle-margin-top, .25rem);font-size:var(--ml-option-subtitle-font-size, .75rem);color:var(--ml-option-subtitle-color, #6b7280);line-height:var(--ml-option-subtitle-line-height, 1.3)}.ml__empty{padding:var(--ml-empty-padding, 1rem .75rem);text-align:center;font-size:var(--ml-empty-font-size, .875rem);color:var(--ml-empty-color, #6b7280)}.ml__loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--ml-loader-padding, 1rem);gap:var(--ml-loader-gap, .5rem)}.ml__loading-text{font-size:var(--ml-loading-text-font-size, .875rem);color:var(--ml-loading-text-color, #6b7280)}.ml__pills{display:flex;flex-wrap:wrap;gap:var(--ml-pills-gap, .5rem);padding:0}.ml__pills:empty{display:none}.ml__pills--bottom{margin-top:var(--ml-pills-margin-bottom, .5rem)}.ml__pills--top{margin-bottom:var(--ml-pills-margin-top, .5rem);order:var(--ml-order-first, -1)}.ml__pills--left{order:var(--ml-order-first, -1);margin-right:var(--ml-pills-margin-left, .25rem);justify-content:flex-end}.ml__pills--right{margin-left:var(--ml-pills-margin-right, .25rem);justify-content:flex-start}.ml__count-display{display:flex;align-items:center}.ml__count-display:empty{display:none}.ml__count-display--bottom{margin-top:var(--ml-count-display-margin-bottom, .5rem)}.ml__count-display--top{margin-bottom:var(--ml-count-display-margin-top, .5rem);order:var(--ml-order-first, -1)}.ml__count-display--left{order:var(--ml-order-first, -1);margin-right:var(--ml-count-display-margin-left, .5rem);justify-content:flex-start}.ml__count-display--right{margin-left:var(--ml-count-display-margin-right, .5rem);justify-content:flex-end}.ml__count-badge-wrapper{display:inline-flex;align-items:center;gap:var(--ml-count-badge-wrapper-gap, .25rem);background:var(--ml-count-badge-wrapper-bg, transparent);border:var(--ml-count-badge-wrapper-border, 1px solid #e5e7eb);border-radius:var(--ml-count-badge-wrapper-border-radius, .25rem);padding:var(--ml-count-badge-wrapper-padding, .25rem .5rem);transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-badge-wrapper:hover{background:var(--ml-count-badge-wrapper-bg-hover, #f9fafb);border-color:var(--ml-count-badge-wrapper-border-color-hover, #3b82f6)}.ml__count-text{display:inline-flex;align-items:center;background:var(--ml-count-text-bg, transparent);border:var(--ml-count-text-border, none);padding:0;font-size:var(--ml-count-text-font-size, .875rem);color:var(--ml-count-text-color, #111827);cursor:pointer;transition:color var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-clear{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:var(--ml-count-clear-size, 1rem);height:var(--ml-count-clear-size, 1rem);padding:0;border:none;background:var(--ml-count-clear-bg, transparent);color:var(--ml-count-clear-color, #6b7280);font-size:var(--ml-count-clear-font-size, 1.125rem);line-height:var(--ml-line-height-none, 1);cursor:pointer;border-radius:var(--ml-count-clear-border-radius, 50%);transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__count-clear:hover{background:var(--ml-count-clear-bg-hover, rgba(59, 130, 246, .2));color:var(--ml-count-clear-color-hover, #3b82f6)}.ml__count-clear:before{content:var(--ml-icon-clear, "×")}.ml__pill{display:inline-flex;align-items:center;height:var(--ml-pill-height, 1.5rem);font-size:var(--ml-pill-font-size, .75rem);font-weight:var(--ml-pill-font-weight, 600);line-height:var(--ml-line-height-none, 1);border-radius:var(--ml-pill-border-radius, .375rem);overflow:hidden;max-width:100%}.ml__pill-text{display:flex;align-items:center;height:100%;padding:var(--ml-pill-text-padding, 0 .5rem);background:var(--ml-pill-text-bg, #eff6ff);color:var(--ml-pill-text-color, #3b82f6);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background-color var(--ml-transition-normal, .2s) ease}.ml__pill-remove{display:flex;align-items:center;justify-content:center;width:var(--ml-pill-remove-width, 1.5rem);height:100%;flex-shrink:0;background:var(--ml-pill-remove-bg, #3b82f6);color:var(--ml-pill-remove-color, #ffffff);border:var(--ml-pill-remove-border, none);cursor:pointer;transition:background-color var(--ml-transition-normal, .2s) ease;font-size:var(--ml-pill-remove-font-size, .75rem)}.ml__pill-remove:hover{background:var(--ml-pill-remove-bg-hover, #2563eb)}.ml__pill-remove:focus{outline:none;box-shadow:var(--ml-pill-remove-box-shadow-focus, 0 0 0 2px rgba(59, 130, 246, .5))}.ml__pill-remove:before{content:var(--ml-icon-remove, "×");font-size:var(--ml-font-size-base, 1rem);line-height:var(--ml-line-height-none, 1)}.ml__pill--more{cursor:pointer}.ml__pill--more .ml__pill-text{background:var(--ml-more-badge-bg, #eff6ff);font-weight:var(--ml-pill-font-weight, 600)}.ml__pill--more:hover .ml__pill-text{background:var(--ml-more-badge-hover-bg, #ffffff)}.ml__pill--more:active .ml__pill-text{background:var(--ml-more-badge-active-bg, #e0f2fe)}.ml__pill-tooltip{position:fixed;z-index:var(--ml-tooltip-z-index, 10000);opacity:0;visibility:hidden;transition:opacity var(--ml-transition-normal, .2s) ease,visibility var(--ml-transition-normal, .2s) ease;background:var(--ml-tooltip-bg, #333);color:var(--ml-tooltip-color, #fff);padding:var(--ml-tooltip-padding, .5rem .75rem);border-radius:var(--ml-tooltip-border-radius, .375rem);font-size:var(--ml-tooltip-font-size, .875rem);line-height:var(--ml-line-height-relaxed, 1.4);max-width:var(--ml-tooltip-max-width, 20rem);word-wrap:break-word;white-space:pre-wrap;box-shadow:var(--ml-tooltip-shadow, 0 2px 8px rgba(0, 0, 0, .15));pointer-events:none}.ml__pill-tooltip--visible{opacity:1;visibility:visible}.ml__selected-popover{display:none;position:absolute;z-index:var(--ml-z-index-popover, 10000);background:var(--ml-selected-popover-bg, #ffffff);border:var(--ml-selected-popover-border, 1px solid #e5e7eb);border-radius:var(--ml-selected-popover-border-radius, .375rem);box-shadow:var(--ml-selected-popover-box-shadow, 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1));width:var(--ml-selected-popover-width, 20rem);max-height:var(--ml-selected-popover-max-height, 20rem);overflow:hidden}.ml__selected-popover--visible{display:flex;flex-direction:column}.ml__selected-popover-header{display:flex;align-items:center;justify-content:space-between;padding:var(--ml-selected-popover-header-padding, .5rem .75rem);background:var(--ml-selected-popover-header-bg, rgba(59, 130, 246, .1));border-bottom:var(--ml-selected-popover-header-border-bottom, 1px solid #e5e7eb);font-size:var(--ml-selected-popover-header-font-size, .875rem);font-weight:var(--ml-selected-popover-header-font-weight, 600);color:var(--ml-selected-popover-header-color, #111827)}.ml__selected-popover-close{display:flex;align-items:center;justify-content:center;width:var(--ml-popover-close-size, 1.5rem);height:var(--ml-popover-close-size, 1.5rem);padding:0;border:none;background:var(--ml-selected-popover-close-bg, transparent);color:var(--ml-selected-popover-close-color, #6b7280);font-size:var(--ml-selected-popover-close-font-size, 1.25rem);line-height:var(--ml-line-height-none, 1);cursor:pointer;border-radius:var(--ml-selected-popover-close-border-radius, 50%);transition:all var(--ml-transition-fast, .15s) var(--ml-easing-snappy, cubic-bezier(.4, 0, .2, 1))}.ml__selected-popover-close:hover{background:var(--ml-selected-popover-close-bg-hover, rgba(59, 130, 246, .2));color:var(--ml-selected-popover-close-color-hover, #3b82f6)}.ml__selected-popover-body{display:flex;flex-direction:column;gap:var(--ml-selected-popover-body-gap, .25rem);padding:var(--ml-selected-popover-body-padding, .5rem);overflow-y:auto;max-height:var(--ml-selected-popover-body-max-height, 18rem)}.ml__selected-popover-body .ml__pill{width:100%}.ml__selected-popover-body .ml__pill-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.ml--rtl .ml__input-wrapper{direction:rtl}.ml--rtl .ml__input{text-align:right;padding-left:var(--ml-input-padding-right, 2.5rem);padding-right:var(--ml-input-padding-h, .75rem)}.ml--rtl .ml__toggle{left:var(--ml-toggle-right, .75rem)!important;right:auto!important}.ml--rtl .ml__count-badge{left:var(--ml-count-badge-offset, 2rem)!important;right:auto!important}.ml--rtl .ml__dropdown{direction:rtl;text-align:right}.ml--rtl .ml__option{flex-direction:row-reverse}.ml--rtl .ml__checkbox{margin-left:var(--ml-spacing-sm, .5rem);margin-right:0}.ml--rtl .ml__option-content{text-align:right}.ml--rtl .ml__option-icon{margin-left:var(--ml-spacing-xs, .25rem);margin-right:0}.ml--rtl .ml__pills{direction:rtl}.ml--rtl .ml__pill{flex-direction:row-reverse}.ml--rtl .ml__pill-remove{border-radius:var(--ml-pill-remove-border-radius-rtl, .375rem) 0 0 var(--ml-pill-remove-border-radius-rtl, .375rem);border-left:var(--ml-pill-remove-border, none);border-right:none}.ml--rtl .ml__pill-text{border-radius:0 var(--ml-pill-text-border-radius-rtl, .375rem) var(--ml-pill-text-border-radius-rtl, .375rem) 0}.ml--rtl .ml__count-display{direction:rtl}.ml--rtl .ml__count-badge-wrapper{flex-direction:row-reverse}.ml--rtl .ml__selected-popover{direction:rtl;text-align:right}.ml--rtl .ml__actions{direction:rtl}.ml--rtl .ml__group-label,.ml--rtl .ml__empty{text-align:right}.ml--rtl .ml__hint{direction:rtl;text-align:right}.ml--xs .ml__input{font-size:var(--ml-font-size-xs, .75rem)}.ml--xs .ml__option{padding:var(--ml-spacing-xs, .25rem) var(--ml-spacing-sm, .5rem)}.ml--xs .ml__option-title{font-size:var(--ml-font-size-xs, .75rem)}.ml--xs .ml__pill{font-size:var(--ml-font-size-2xs, .625rem)}.ml--sm .ml__input,.ml--sm .ml__option-title{font-size:var(--ml-font-size-xs, .75rem)}.ml--lg .ml__input,.ml--lg .ml__option-title{font-size:var(--ml-font-size-base, 1rem)}.ml--lg .ml__pill{font-size:var(--ml-font-size-sm, .875rem)}.ml--xl .ml__input,.ml--xl .ml__option-title{font-size:var(--ml-font-size-lg, 1.125rem)}.ml--xl .ml__pill{font-size:var(--ml-font-size-base, 1rem)}.ml--disabled .ml__input{opacity:var(--ml-disabled-input-opacity, .6);cursor:not-allowed;background:var(--ml-input-bg-disabled, rgba(107, 114, 128, .05))}.ml--disabled .ml__toggle{opacity:var(--ml-disabled-input-opacity, .6)}.ml--no-checkboxes .ml__option{gap:0;padding-left:var(--ml-option-padding-h, .75rem)}.ml--no-checkboxes .ml__option-content{padding-left:0}.ml-debug-info{margin-top:.25rem;padding:.25rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;font-size:.75rem;color:#111827}.ml-debug-info details summary{cursor:pointer;font-weight:600;color:#2563eb;-webkit-user-select:none;user-select:none;padding:.25rem;border-radius:.25rem}.ml-debug-info details summary:hover{background-color:#f3f4f6}.ml-debug-info details summary:focus{outline:2px solid #3b82f6;outline-offset:2px}.ml-debug-info .ml-debug-stats{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem;padding:.25rem;background-color:#fff;border-radius:.25rem}.ml-debug-info .ml-debug-stats span{display:flex;justify-content:space-between;padding:2px 4px;font-family:monospace;font-size:.625rem}.ml-debug-info .ml-debug-stats span:before{content:"•";margin-right:.25rem;color:#3b82f6}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@keenmate/web-multiselect",
3
- "version": "1.0.0-rc05",
3
+ "version": "1.0.0-rc08",
4
4
  "description": "Lightweight multiselect web component with typeahead search, rich content support, and excellent keyboard navigation",
5
5
  "type": "module",
6
6
  "main": "./dist/multiselect.umd.js",
@@ -0,0 +1,379 @@
1
+ // ==============================================================================
2
+ // CSS CUSTOM PROPERTIES (:host level)
3
+ // ==============================================================================
4
+ // This file defines all CSS custom properties at the :host level, making them:
5
+ // - Inspectable in browser DevTools
6
+ // - Overridable from outside Shadow DOM
7
+ // - Self-documenting in compiled CSS
8
+ //
9
+ // All variables use SCSS variable fallbacks for reliability.
10
+ // External overrides will take precedence over these defaults.
11
+ //
12
+ // Usage from outside Shadow DOM:
13
+ // multi-select {
14
+ // --ml-accent-color: #10b981;
15
+ // --ml-input-border-radius: 0.5rem;
16
+ // }
17
+ // ==============================================================================
18
+
19
+ @use 'variables' as *;
20
+
21
+ :host {
22
+ // ==========================================================================
23
+ // COLORS & THEME
24
+ // ==========================================================================
25
+
26
+ // Accent Colors
27
+ --ml-accent-color: #{$ml-accent-color};
28
+ --ml-accent-color-hover: #{$ml-accent-color-hover};
29
+ --ml-accent-color-active: #{$ml-accent-color-active};
30
+
31
+ // Text Colors
32
+ --ml-text-primary: #{$ml-text-primary};
33
+ --ml-text-secondary: #{$ml-text-secondary};
34
+ --ml-text-white: #{$ml-text-white};
35
+
36
+ // Background Colors
37
+ --ml-primary-bg: #{$ml-primary-bg};
38
+ --ml-primary-bg-hover: #{$ml-primary-bg-hover};
39
+ --ml-border-color: #{$ml-border-color};
40
+
41
+ // ==========================================================================
42
+ // INPUT COMPONENT
43
+ // ==========================================================================
44
+
45
+ --ml-input-padding: #{$ml-input-padding};
46
+ --ml-input-padding-right: #{$ml-input-padding-right};
47
+ --ml-input-font-size: #{$ml-input-font-size};
48
+ --ml-input-border-style: #{$ml-input-border-style};
49
+ --ml-input-border-radius: #{$ml-input-border-radius};
50
+ --ml-input-bg: #{$ml-input-bg};
51
+ --ml-input-text: #{$ml-input-text};
52
+ --ml-input-focus-border-color: #{$ml-input-focus-border-color};
53
+ --ml-input-placeholder-color: #{$ml-input-placeholder-color};
54
+ --ml-input-bg-disabled: #{$ml-input-bg-disabled};
55
+
56
+ // ==========================================================================
57
+ // TOGGLE ICON
58
+ // ==========================================================================
59
+
60
+ --ml-toggle-right: #{$ml-toggle-right};
61
+ --ml-toggle-color: #{$ml-toggle-color};
62
+ --ml-transform-center-y: #{$ml-transform-center-y};
63
+ --ml-transform-rotate-180: #{$ml-transform-rotate-180};
64
+
65
+ // ==========================================================================
66
+ // COUNT BADGE (in input)
67
+ // ==========================================================================
68
+
69
+ --ml-count-badge-offset: #{$ml-count-badge-offset};
70
+ --ml-count-badge-padding: #{$ml-count-badge-padding};
71
+ --ml-count-badge-bg: #{$ml-count-badge-bg};
72
+ --ml-count-badge-color: #{$ml-count-badge-color};
73
+ --ml-count-badge-font-size: #{$ml-count-badge-font-size};
74
+ --ml-count-badge-font-weight: #{$ml-count-badge-font-weight};
75
+ --ml-count-badge-border-radius: #{$ml-count-badge-border-radius};
76
+ --ml-count-badge-bg-hover: #{$ml-count-badge-bg-hover};
77
+ --ml-transform-scale-hover: #{$ml-transform-scale-hover};
78
+
79
+ // ==========================================================================
80
+ // FLOATING HINT
81
+ // ==========================================================================
82
+
83
+ --ml-hint-padding: #{$ml-hint-padding};
84
+ --ml-hint-bg: #{$ml-hint-bg};
85
+ --ml-hint-border: #{$ml-hint-border};
86
+ --ml-hint-border-radius: #{$ml-hint-border-radius};
87
+ --ml-hint-box-shadow: #{$ml-hint-box-shadow};
88
+ --ml-hint-font-size: #{$ml-hint-font-size};
89
+ --ml-hint-color: #{$ml-hint-color};
90
+ --ml-line-height-relaxed: #{$ml-line-height-relaxed};
91
+
92
+ // ==========================================================================
93
+ // DROPDOWN
94
+ // ==========================================================================
95
+
96
+ --ml-dropdown-bg: #{$ml-dropdown-bg};
97
+ --ml-dropdown-border: #{$ml-dropdown-border};
98
+ --ml-dropdown-border-radius: #{$ml-dropdown-border-radius};
99
+ --ml-dropdown-box-shadow: #{$ml-dropdown-box-shadow};
100
+ --ml-dropdown-max-height: #{$ml-dropdown-max-height};
101
+ --ml-dropdown-color: #{$ml-dropdown-color};
102
+ --ml-z-index-dropdown: #{$ml-z-index-dropdown};
103
+ --ml-z-index-sticky: #{$ml-z-index-sticky};
104
+
105
+ // ==========================================================================
106
+ // DROPDOWN ACTIONS
107
+ // ==========================================================================
108
+
109
+ --ml-actions-gap: #{$ml-actions-gap};
110
+ --ml-actions-padding: #{$ml-actions-padding};
111
+ --ml-actions-border-bottom: #{$ml-actions-border-bottom};
112
+ --ml-actions-bg: #{$ml-actions-bg};
113
+
114
+ // Action Button
115
+ --ml-action-btn-padding: #{$ml-action-btn-padding};
116
+ --ml-action-btn-font-size: #{$ml-action-btn-font-size};
117
+ --ml-action-btn-border: #{$ml-action-btn-border};
118
+ --ml-action-btn-border-radius: #{$ml-action-btn-border-radius};
119
+ --ml-action-btn-bg: #{$ml-action-btn-bg};
120
+ --ml-action-btn-color: #{$ml-action-btn-color};
121
+ --ml-action-btn-bg-hover: #{$ml-action-btn-bg-hover};
122
+ --ml-action-btn-border-color-hover: #{$ml-action-btn-border-color-hover};
123
+ --ml-transform-scale-active: #{$ml-transform-scale-active};
124
+
125
+ // ==========================================================================
126
+ // OPTIONS CONTAINER & GROUPS
127
+ // ==========================================================================
128
+
129
+ --ml-options-padding: #{$ml-options-padding};
130
+
131
+ // Group
132
+ --ml-group-border-top: #{$ml-group-border-top};
133
+ --ml-group-margin-top: #{$ml-group-margin-top};
134
+ --ml-group-padding-top: #{$ml-group-padding-top};
135
+
136
+ // Group Label
137
+ --ml-group-label-padding: #{$ml-group-label-padding};
138
+ --ml-group-label-font-size: #{$ml-group-label-font-size};
139
+ --ml-group-label-font-weight: #{$ml-group-label-font-weight};
140
+ --ml-group-label-color: #{$ml-group-label-color};
141
+ --ml-group-label-transform: #{$ml-group-label-transform};
142
+ --ml-group-label-letter-spacing: #{$ml-group-label-letter-spacing};
143
+
144
+ // ==========================================================================
145
+ // INDIVIDUAL OPTIONS
146
+ // ==========================================================================
147
+
148
+ --ml-option-gap: #{$ml-option-gap};
149
+ --ml-option-padding: #{$ml-option-padding};
150
+ --ml-option-padding-h: #{$ml-option-padding-h};
151
+ --ml-option-bg: #{$ml-option-bg};
152
+ --ml-option-bg-hover: #{$ml-option-bg-hover};
153
+ --ml-option-bg-focused: #{$ml-option-bg-focused};
154
+ --ml-option-outline-focused: #{$ml-option-outline-focused};
155
+ --ml-option-focus-outline-offset: #{$ml-option-focus-outline-offset};
156
+ --ml-option-bg-matched: #{$ml-option-bg-matched};
157
+ --ml-option-border-matched: #{$ml-option-border-matched};
158
+ --ml-option-bg-selected: #{$ml-option-bg-selected};
159
+ --ml-disabled-opacity: #{$ml-disabled-opacity};
160
+
161
+ // ==========================================================================
162
+ // OPTION CONTENT
163
+ // ==========================================================================
164
+
165
+ --ml-option-content-gap: #{$ml-option-content-gap};
166
+
167
+ // Option Icon
168
+ --ml-option-icon-size: #{$ml-option-icon-size};
169
+ --ml-option-icon-font-size: #{$ml-option-icon-font-size};
170
+
171
+ // Option Title
172
+ --ml-option-title-font-size: #{$ml-option-title-font-size};
173
+ --ml-option-title-color: #{$ml-option-title-color};
174
+ --ml-option-mark-bg: #{$ml-option-mark-bg};
175
+ --ml-option-mark-color: #{$ml-option-mark-color};
176
+ --ml-option-mark-font-weight: #{$ml-option-mark-font-weight};
177
+
178
+ // Option Subtitle
179
+ --ml-option-subtitle-margin-top: #{$ml-option-subtitle-margin-top};
180
+ --ml-option-subtitle-font-size: #{$ml-option-subtitle-font-size};
181
+ --ml-option-subtitle-color: #{$ml-option-subtitle-color};
182
+ --ml-option-subtitle-line-height: #{$ml-option-subtitle-line-height};
183
+
184
+ // Checkbox
185
+ --ml-checkbox-margin-top: #{$ml-checkbox-margin-top};
186
+
187
+ // ==========================================================================
188
+ // EMPTY & LOADING STATES
189
+ // ==========================================================================
190
+
191
+ // Empty State
192
+ --ml-empty-padding: #{$ml-empty-padding};
193
+ --ml-empty-font-size: #{$ml-empty-font-size};
194
+ --ml-empty-color: #{$ml-empty-color};
195
+
196
+ // Loader
197
+ --ml-loader-padding: #{$ml-loader-padding};
198
+ --ml-loader-gap: #{$ml-loader-gap};
199
+
200
+ // Loading Text
201
+ --ml-loading-text-font-size: #{$ml-loading-text-font-size};
202
+ --ml-loading-text-color: #{$ml-loading-text-color};
203
+
204
+ // ==========================================================================
205
+ // PILLS DISPLAY
206
+ // ==========================================================================
207
+
208
+ --ml-pills-gap: #{$ml-pills-gap};
209
+ --ml-pills-margin-bottom: #{$ml-pills-margin-bottom};
210
+ --ml-pills-margin-top: #{$ml-pills-margin-top};
211
+ --ml-pills-margin-left: #{$ml-pills-margin-left};
212
+ --ml-pills-margin-right: #{$ml-pills-margin-right};
213
+
214
+ // Individual Pill
215
+ --ml-pill-gap: #{$ml-pill-gap};
216
+ --ml-pill-height: #{$ml-pill-height};
217
+ --ml-pill-font-size: #{$ml-pill-font-size};
218
+ --ml-pill-font-weight: #{$ml-pill-font-weight};
219
+ --ml-pill-border-radius: #{$ml-pill-border-radius};
220
+ --ml-pill-bg: #{$ml-pill-bg};
221
+ --ml-pill-bg-hover: #{$ml-pill-bg-hover};
222
+ --ml-pill-bg-active: #{$ml-pill-bg-active};
223
+ --ml-order-first: #{$ml-order-first};
224
+
225
+ // ==========================================================================
226
+ // PILL TEXT & REMOVE BUTTON
227
+ // ==========================================================================
228
+
229
+ // Pill Text
230
+ --ml-pill-text-padding: #{$ml-pill-text-padding};
231
+ --ml-pill-text-bg: #{$ml-pill-text-bg};
232
+ --ml-pill-text-color: #{$ml-pill-text-color};
233
+
234
+ // Pill Remove Button
235
+ --ml-pill-remove-width: #{$ml-pill-remove-width};
236
+ --ml-pill-remove-bg: #{$ml-pill-remove-bg};
237
+ --ml-pill-remove-color: #{$ml-pill-remove-color};
238
+ --ml-pill-remove-border: #{$ml-pill-remove-border};
239
+ --ml-pill-remove-font-size: #{$ml-pill-remove-font-size};
240
+ --ml-pill-remove-bg-hover: #{$ml-pill-remove-bg-hover};
241
+ --ml-pill-remove-box-shadow-focus: #{$ml-pill-remove-box-shadow-focus};
242
+ --ml-icon-remove: "#{$ml-icon-remove}";
243
+
244
+ // ==========================================================================
245
+ // "+X MORE" BADGE
246
+ // ==========================================================================
247
+
248
+ --ml-more-badge-bg: #{$ml-more-badge-bg};
249
+ --ml-more-badge-hover-bg: #{$ml-more-badge-hover-bg};
250
+ --ml-more-badge-active-bg: #{$ml-more-badge-active-bg};
251
+
252
+ // ==========================================================================
253
+ // COUNT DISPLAY MODE
254
+ // ==========================================================================
255
+
256
+ --ml-count-display-margin-bottom: #{$ml-count-display-margin-bottom};
257
+ --ml-count-display-margin-top: #{$ml-count-display-margin-top};
258
+ --ml-count-display-margin-left: #{$ml-count-display-margin-left};
259
+ --ml-count-display-margin-right: #{$ml-count-display-margin-right};
260
+
261
+ // Count Badge Wrapper
262
+ --ml-count-badge-wrapper-bg: #{$ml-count-badge-wrapper-bg};
263
+ --ml-count-badge-wrapper-border: #{$ml-count-badge-wrapper-border};
264
+ --ml-count-badge-wrapper-border-radius: #{$ml-count-badge-wrapper-border-radius};
265
+ --ml-count-badge-wrapper-padding: #{$ml-count-badge-wrapper-padding};
266
+ --ml-count-badge-wrapper-gap: #{$ml-count-badge-wrapper-gap};
267
+ --ml-count-badge-wrapper-bg-hover: #{$ml-count-badge-wrapper-bg-hover};
268
+ --ml-count-badge-wrapper-border-color-hover: #{$ml-count-badge-wrapper-border-color-hover};
269
+
270
+ // ==========================================================================
271
+ // COUNT TEXT & CLEAR BUTTON
272
+ // ==========================================================================
273
+
274
+ // Count Text
275
+ --ml-count-text-bg: #{$ml-count-text-bg};
276
+ --ml-count-text-border: #{$ml-count-text-border};
277
+ --ml-count-text-font-size: #{$ml-count-text-font-size};
278
+ --ml-count-text-color: #{$ml-count-text-color};
279
+
280
+ // Count Clear Button
281
+ --ml-count-clear-size: #{$ml-count-clear-size};
282
+ --ml-count-clear-bg: #{$ml-count-clear-bg};
283
+ --ml-count-clear-color: #{$ml-count-clear-color};
284
+ --ml-count-clear-font-size: #{$ml-count-clear-font-size};
285
+ --ml-count-clear-border-radius: #{$ml-count-clear-border-radius};
286
+ --ml-count-clear-bg-hover: #{$ml-count-clear-bg-hover};
287
+ --ml-count-clear-color-hover: #{$ml-count-clear-color-hover};
288
+ --ml-icon-clear: "#{$ml-icon-clear}";
289
+
290
+ // ==========================================================================
291
+ // TOOLTIPS
292
+ // ==========================================================================
293
+
294
+ --ml-tooltip-bg: #{$ml-tooltip-bg};
295
+ --ml-tooltip-color: #{$ml-tooltip-color};
296
+ --ml-tooltip-padding: #{$ml-tooltip-padding};
297
+ --ml-tooltip-border-radius: #{$ml-tooltip-border-radius};
298
+ --ml-tooltip-font-size: #{$ml-tooltip-font-size};
299
+ --ml-tooltip-max-width: #{$ml-tooltip-max-width};
300
+ --ml-tooltip-shadow: #{$ml-tooltip-shadow};
301
+ --ml-tooltip-z-index: #{$ml-tooltip-z-index};
302
+
303
+ // ==========================================================================
304
+ // SELECTED POPOVER
305
+ // ==========================================================================
306
+
307
+ --ml-z-index-popover: #{$ml-z-index-popover};
308
+ --ml-selected-popover-width: #{$ml-selected-popover-width};
309
+ --ml-selected-popover-max-height: #{$ml-selected-popover-max-height};
310
+ --ml-selected-popover-bg: #{$ml-selected-popover-bg};
311
+ --ml-selected-popover-border: #{$ml-selected-popover-border};
312
+ --ml-selected-popover-border-radius: #{$ml-selected-popover-border-radius};
313
+ --ml-selected-popover-box-shadow: #{$ml-selected-popover-box-shadow};
314
+
315
+ // Popover Header
316
+ --ml-selected-popover-header-padding: #{$ml-selected-popover-header-padding};
317
+ --ml-selected-popover-header-bg: #{$ml-selected-popover-header-bg};
318
+ --ml-selected-popover-header-border-bottom: #{$ml-selected-popover-header-border-bottom};
319
+ --ml-selected-popover-header-font-size: #{$ml-selected-popover-header-font-size};
320
+ --ml-selected-popover-header-font-weight: #{$ml-selected-popover-header-font-weight};
321
+ --ml-selected-popover-header-color: #{$ml-selected-popover-header-color};
322
+
323
+ // ==========================================================================
324
+ // POPOVER CLOSE BUTTON
325
+ // ==========================================================================
326
+
327
+ --ml-popover-close-size: #{$ml-popover-close-size};
328
+ --ml-selected-popover-close-bg: #{$ml-selected-popover-close-bg};
329
+ --ml-selected-popover-close-color: #{$ml-selected-popover-close-color};
330
+ --ml-selected-popover-close-font-size: #{$ml-selected-popover-close-font-size};
331
+ --ml-selected-popover-close-border-radius: #{$ml-selected-popover-close-border-radius};
332
+ --ml-selected-popover-close-bg-hover: #{$ml-selected-popover-close-bg-hover};
333
+ --ml-selected-popover-close-color-hover: #{$ml-selected-popover-close-color-hover};
334
+
335
+ // ==========================================================================
336
+ // POPOVER BODY
337
+ // ==========================================================================
338
+
339
+ --ml-selected-popover-body-gap: #{$ml-selected-popover-body-gap};
340
+ --ml-selected-popover-body-padding: #{$ml-selected-popover-body-padding};
341
+ --ml-selected-popover-body-max-height: #{$ml-selected-popover-body-max-height};
342
+
343
+ // ==========================================================================
344
+ // TYPOGRAPHY SCALE
345
+ // ==========================================================================
346
+
347
+ --ml-font-size-2xs: #{$ml-font-size-2xs};
348
+ --ml-font-size-xs: #{$ml-font-size-xs};
349
+ --ml-font-size-sm: #{$ml-font-size-sm};
350
+ --ml-font-size-base: #{$ml-font-size-base};
351
+ --ml-font-size-lg: #{$ml-font-size-lg};
352
+ --ml-font-weight-medium: #{$ml-font-weight-medium};
353
+ --ml-font-weight-semibold: #{$ml-font-weight-semibold};
354
+ --ml-line-height-none: #{$ml-line-height-none};
355
+
356
+ // ==========================================================================
357
+ // SPACING & SIZING
358
+ // ==========================================================================
359
+
360
+ --ml-spacing-xs: #{$ml-spacing-xs};
361
+ --ml-spacing-sm: #{$ml-spacing-sm};
362
+ --ml-spacing-md: #{$ml-spacing-md};
363
+ --ml-spacing-lg: #{$ml-spacing-lg};
364
+
365
+ // ==========================================================================
366
+ // TRANSITIONS & EFFECTS
367
+ // ==========================================================================
368
+
369
+ --ml-transition-fast: #{$ml-transition-fast};
370
+ --ml-transition-normal: #{$ml-transition-normal};
371
+ --ml-easing-snappy: #{$ml-easing-snappy};
372
+
373
+ // ==========================================================================
374
+ // OPACITY VALUES
375
+ // ==========================================================================
376
+
377
+ --ml-placeholder-opacity: #{$ml-placeholder-opacity};
378
+ --ml-disabled-input-opacity: #{$ml-disabled-input-opacity};
379
+ }
@@ -130,11 +130,20 @@
130
130
  box-shadow: var(--ml-dropdown-box-shadow, $ml-dropdown-box-shadow);
131
131
  max-height: var(--ml-dropdown-max-height, $ml-dropdown-max-height);
132
132
  overflow-y: auto;
133
+ overscroll-behavior: contain;
134
+ touch-action: pan-y;
135
+ -webkit-overflow-scrolling: touch;
133
136
  color: var(--ml-dropdown-color, $ml-dropdown-color);
134
137
 
135
138
  &--visible {
136
139
  display: block;
137
140
  }
141
+
142
+ &--virtual {
143
+ // In virtual scroll mode, let the options container handle scrolling
144
+ overflow-y: visible;
145
+ max-height: none;
146
+ }
138
147
  }
139
148
 
140
149
  // ==============================================================================
@@ -14,6 +14,19 @@
14
14
  padding: var(--ml-options-padding, $ml-options-padding);
15
15
  }
16
16
 
17
+ // Virtual scroll - enforce consistent heights
18
+ .ml__options--virtual {
19
+ // overflow and position are set inline for proper dimensions
20
+
21
+ .ml__option {
22
+ height: var(--ml-option-height, 50px);
23
+ min-height: var(--ml-option-height, 50px);
24
+ max-height: var(--ml-option-height, 50px);
25
+ overflow: hidden;
26
+ box-sizing: border-box;
27
+ }
28
+ }
29
+
17
30
  // ==============================================================================
18
31
  // GROUPS
19
32
  // ==============================================================================
@@ -60,6 +73,11 @@
60
73
  outline-offset: var(--ml-option-focus-outline-offset, $ml-option-focus-outline-offset);
61
74
  }
62
75
 
76
+ &--matched {
77
+ background: var(--ml-option-bg-matched, $ml-option-bg-matched);
78
+ border-left: var(--ml-option-border-matched, $ml-option-border-matched);
79
+ }
80
+
63
81
  &--selected {
64
82
  background: var(--ml-option-bg-selected, $ml-option-bg-selected);
65
83
  }
@@ -283,6 +283,8 @@ $ml-option-bg: transparent !default;
283
283
  $ml-option-bg-hover: $ml-option-hover-bg !default;
284
284
  $ml-option-bg-focused: $ml-option-hover-bg !default;
285
285
  $ml-option-outline-focused: $ml-focus-outline-width solid $ml-accent-color !default;
286
+ $ml-option-bg-matched: rgba($ml-accent-color, 0.08) !default;
287
+ $ml-option-border-matched: 3px solid rgba($ml-accent-color, 0.4) !default;
286
288
  $ml-option-bg-selected: rgba($ml-accent-color, $ml-opacity-option-selected-bg) !default;
287
289
 
288
290
  // Option Content
@@ -5,6 +5,7 @@
5
5
  //
6
6
  // File structure:
7
7
  // - _variables.scss : All variables (base primitives + semantic)
8
+ // - _css-variables.scss : CSS custom properties at :host level (for theming)
8
9
  // - _base.scss : FOUC prevention + layout containers
9
10
  // - _input-dropdown.scss : Input, toggle, badge, hint, dropdown, actions
10
11
  // - _options.scss : Options list, groups, checkbox, content, states
@@ -16,6 +17,7 @@
16
17
 
17
18
  // Import all partials in dependency order
18
19
  @use 'variables';
20
+ @use 'css-variables'; // Define CSS custom properties at :host level
19
21
  @use 'base';
20
22
  @use 'input-dropdown';
21
23
  @use 'options';