/* ============================================================
   ENTITY AUTOCOMPLETE
   Composant d'autocomplétion pour sélectionner une entité.
   Wrap un <select> natif pour offrir une UX d'autocomplete :
   input texte + suggestions filtrées en live.
   ============================================================ */


/* ============================================================
   WRAPPER PRINCIPAL
   ============================================================ */

.entity-autocomplete-wrapper {
    position: relative;
    width: 100%;
}

/* Cache le <select> natif quand le JS prend la main (fallback accessible) */
.entity-autocomplete-native {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}


/* ============================================================
   INPUT + BOUTON CLEAR
   ============================================================ */

.entity-autocomplete-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.entity-autocomplete-input {
    width: 100%;
    padding: 0.5rem 2.25rem 0.5rem 0.875rem;
    background-color: var(--color-surface);
    color: var(--color-text);
    border: 1px solid var(--color-input-border);
    border-radius: 8px;
    font-size: 0.9375rem;
    transition: border-color 0.15s ease;
}

.entity-autocomplete-input:hover {
    border-color: var(--color-primary);
}

.entity-autocomplete-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.entity-autocomplete-clear {
    position: absolute;
    right: 0.5rem;
    top: 50%;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    border: none;
    border-radius: 9999px;
    background-color: color-mix(in srgb, var(--color-text) 12%, transparent);
    color: var(--color-text);
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.entity-autocomplete-clear svg {
    width: 0.875rem;
    height: 0.875rem;
}

.entity-autocomplete-clear:hover {
    background-color: color-mix(in srgb, var(--color-text) 25%, transparent);
}

.entity-autocomplete-clear:hover {
    background-color: color-mix(in srgb, var(--color-text) 25%, transparent);
}


/* ============================================================
   LISTE DES SUGGESTIONS
   ============================================================ */

.entity-autocomplete-suggestions {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    max-height: 240px;
    overflow-y: auto;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
    z-index: 20;
    list-style: none;
    margin: 0;
    padding: 0.25rem;
}

html.dark .entity-autocomplete-suggestions {
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4);
}

.entity-autocomplete-suggestion {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    cursor: pointer;
    color: var(--color-text);
    font-size: 0.9375rem;
    transition: background-color 0.15s ease;
}

.entity-autocomplete-suggestion:hover,
.entity-autocomplete-suggestion.is-highlighted {
    background-color: color-mix(in srgb, var(--color-primary) 12%, transparent);
}

html.dark .entity-autocomplete-suggestion:hover,
html.dark .entity-autocomplete-suggestion.is-highlighted {
    background-color: color-mix(in srgb, var(--color-primary) 20%, transparent);
}

.entity-autocomplete-suggestion-emoji {
    font-size: 1.125rem;
    flex-shrink: 0;
}

.entity-autocomplete-suggestion-image {
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 4px;
    object-fit: cover;
    flex-shrink: 0;
}

.entity-autocomplete-suggestion-label {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}


/* ============================================================
   ÉTAT VIDE
   ============================================================ */

.entity-autocomplete-empty {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    padding: 0.75rem;
    text-align: center;
    color: var(--color-text);
    font-size: 0.875rem;
    font-style: italic;
    margin: 0;
    background-color: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--color-primary) 25%, transparent);
    border-radius: 8px;
    z-index: 20;
}

html.dark .entity-autocomplete-empty {
    background-color: color-mix(in srgb, var(--color-primary) 15%, var(--color-surface));
    border-color: color-mix(in srgb, var(--color-primary) 40%, transparent);
}

/* ============================================================
   ADAPTATION POUR MODALE FORMULAIRE
   ============================================================
   Dans une modale formulaire, on limite la hauteur du dropdown
   pour ne pas trop pousser le contenu de la modale. 
   Scroll interne pour le reste.
   ============================================================ */
.form-modal-content .entity-autocomplete-suggestions {
    max-height: 8rem;
}

/* ============================================================
   HINT INFORMATIF (LIMITE DE RÉSULTATS)
   ============================================================
   Affiché quand le nombre total de résultats dépasse la limite
   configurée (initialLimit ou maxResults). Texte du type :
   "+ X recettes — tape pour rechercher" ou "— affine ta recherche".
   ============================================================ */
.entity-autocomplete-hint {
    list-style: none;
    padding: 0.5rem 0.75rem;
    margin-top: 0.25rem;
    border-top: 1px solid var(--color-border);
    color: var(--color-text);
    opacity: 0.65;
    font-size: 0.8125rem;
    font-style: italic;
    text-align: center;
    cursor: default;
}