.e-search-form,
.elementor-search-form,
.search-form { position: relative !important; }

.opto-search-dropdown {
    position: absolute !important;
    top: calc(100% + 6px);
    left: 0;
    min-width: 100%;
    width: 420px;
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0,0,0,.14);
    z-index: 99999;
    overflow: hidden;
}

.opto-search-item {
    display: flex !important;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    text-decoration: none !important;
    color: inherit;
    border-bottom: 1px solid #f2f2f2;
    transition: background .12s;
    cursor: pointer;
}

.opto-search-item:hover,
.opto-search-item.active { background: #f7f5fc; }

.opto-search-item img {
    width: 52px !important;
    height: 52px !important;
    object-fit: contain;
    flex-shrink: 0;
    background: #f5f5f5;
    border-radius: 4px;
}

.opto-search-item-info { flex: 1; min-width: 0; }

.opto-search-item-name {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #2F2258;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.opto-search-item-name mark { background: none; color: #e3222a; font-weight: 700; }
.opto-search-item-meta { display: block; font-size: 11px; color: #999; margin-top: 2px; }

.opto-search-item-price {
    font-size: 13px;
    font-weight: 700;
    color: #2F2258;
    white-space: nowrap;
    flex-shrink: 0;
}

.opto-search-view-all {
    display: block;
    padding: 10px 14px;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    color: #fff !important;
    background: #2F2258;
    text-decoration: none !important;
    transition: background .12s;
}

.opto-search-view-all:hover { background: #3d2e73; color: #fff !important; }

.opto-search-empty,
.opto-search-loading {
    padding: 16px;
    color: #888;
    font-size: 13px;
    text-align: center;
}
